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(54)Titie: CDMA MODEM 

(57) Abstract 

A CDMA modem 
includes a modem transmitter 
having: a code generator 
which provides an associated 
pilot code signal and which 
generates a plurality of 
message code signals; a 
spreading circuit which 
produces a spread-spectrum 
message signal by combming 
each of the information 
signals with a respective 
one of the message code 
signals; and a global pilot 
code generator that provides 
a global pilot code signal 
to which the message code 
signals are synchronized. 
The CDMA modem also 
includes a modem receiver 
having an associated pilot 
code generator and a group 
of associated pilot code 
comelators for correlating 
code-phase delayed versions 
of the associated pilot signal 
with a receive CDM signal 

to produce a despread associated pilot signal. The code phase of the associated pUot signal is changed rtssponsive to an acquisiUon signal 
value until a pilot signal is received. TTie associated pUot code tracking logic adjusts the associated pilot code signal in phase responsive to 
the acquisiUon signal so that the signal power level of the despread associated pilot code signal is maximized Fmally, the CDMA modem 
receiver includes a group of message signal acquisition circuits, each including a pluraUty of receive message signal coirclators which 
correlate respecuvc local received message code signal to the CDM signal to produce a respective despread itceived message signal 




FOR THE PURPOSES OF INFORMATION ONLY 



Codes used to identify States party to the PCX on the front pages of pamphlets publishmg intonational 
applications under the PCX. 



AM 


Annenia 


GB 


United Kingdom 


MW 


Malawi 


AT 


Austria 


GE 


Geofgia 


MX 


Mexico 


AU 


Australia 


GN 


Guinea 


NE 


Niger 


BB 


Barbados 


GR 


Greece 


NL 


Netherlands 


BE 


Belgiuni 


HU 


Hungary 


NO 


Norway 


BF 


Buridna Paso 


IE 


Ireland 


NZ 


New Zealand 


BG 


Bulgaria 


IT 


Italy 


PL 


Poland 


BJ 


Benin 


JP 


Japan 


PT 


Ptmugal 


BR 


Brazil 


KE 


Kenya 


RO 


Romania 


BY 


Betanis 


KG 


Kytgystan 


RU 


Russian Fedetatioa 


CA 


Canada 


KP 


DetnocraUc People's Republic 


SD 


Sudan 


CF 


Central African Republic 




of Korea 


SE 


Sweden 


CG 


Congo 


KR 


Rqniblic of Korea 


SG 


Singapore . 


CH 


Switzerland 


KZ 


Kazakhstan 


SI 


Slovenia 


a 


Cate d'lvoiie 


U 


Liechtenstein 


SK 


Slovakia 


CM 


Cameroon 


LK 


Sri Lanka 


SN 


Senega] 


CN 


China 


LR 


Liberia 


SZ 


Swaziland 


cs 


Czechoslovakia 


LT 


Lithuania 


TD 


Chad 


cz 


Czech Republic 


LU 


Luxembourg 


TG 


Togo 


DE 


Germany 


LV 


Latvia 


TJ 


T^kistan 


DK 


Demnaric 


MC 


Monaco 


TT 


"ninidad and Tobago 


BE 


Estonia 


MD 


Republic of Moldova 


UA 


Ukraine 


ES 


Spain 


MG 




UG 


Uganda 


n 


Finland 


ML 


Mali 


US 


United States of America 


FR 


Prance 


MN 


Mongolia 


uz 


Uzbekistan 


GA 


Gabon 


MR 


Mauritania 


VN 


Viet Nam 



wo 97/02675 



PCT/US96/11059 



CDMA MODEM 

BACKGROUND OF THE INVENTION 

Providing quality telecommunication services to user groups which are clasified as 
remote, such as rural telephone systems and telephone systems in underdeveloped 
countries, has proved to be a challenge over recent years. The past needs created by these 
services have been partially satisfied by wireless radio services, such as fixed or mobile 
frequency division multiplex (FDM), fi:equency division multiple access (FDMA), time 
division multiplex (TDM), time division multiple access (TDMA) systems, combination 
fi-equency and time division systems (FD/TDMA), and other land mobile radio 
systems.Often, these remote services are faced with more potential users than can be 
supported simultaneously by their frequency or spectral bandwidth capacity. 

Recognizing these limitations, recent advances in wireless communications have 
used spread spectrum modulation techniques to provide simultaneous communication by 
multiple users. Spread spectrum modulation refers to modulating a information signal 
with a spreading code signal; the spreadmg code signal being generated by a code 
generator where the period Tc of the spreading code is substantially less than the period of 
the information data bit or symbol signal. The code may modulate the carrier firequency 
upon which the information has been sent, called frequency-hopped spreadmg, or may 
directly modulate the signal by multiplying the spreading code with the information data 
signal, called direct-sequence spreading (DS). Spread-spectrum modulation produces a 
signal with bandwidth substantially greater than that required to transmit the information 
signal, and synchronous reception and despreading of the signal at the receiver 
demodulator recovers the original mformation. The synchronous demodulator uses a 
reference signal to synchronize the despreadmg circuits to the input spread-spectrum 
modulated signal in order to recover the carrier and information signals. The reference 
signal can be a spreading code which is not modulated by an information signal. 

Spread-spectrum modulation in wireless networks offers many advantages because 
multiple users may use the same frequency band widi minunal interference to each user's 
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receiver. Spread-spectrum modulation also reduces effects from other souices of 
interference. In addition, synchronous ^read-spectium modulation and demodulation 
techniques may be expanded by providing multiple message channels for a user, each 
spread with a different spreading code, while still transmitting only a single reference 
signal to the user. 

One area in which spread-spectrum techniques are used is in the field of mobile 
cellular communications to provide personal communication services (PCS). Such systems 
desirably support large numbers of users, control Etoppler shift and fade, and provide 
high speed digital data signals with low bit error rates. These systems employ a femily of 
orthogonal or quasi-orthogonal spreading codes, with a pilot spreading code sequaice 
synchronized to the family of codes. Each user is assigned one of the spreading codes as a 
spreading function. Related problems of such a Systran arc: supporting a large number of 
users with the orthogonal codes, handling reduced power available to remote units, and 
handling multipath fading effects. Solutions to such problems include using phased-anay 
antennas to generate multiple steerable beams, using very long orthogonal or quasi- 
orthogonal code sequences which are reused by cyclic shifting of the code synchronized to 
a central reference, and diversity combining of multipath signals. 

SUMMARY OF THE INVENTION 

An exemplary system which includes a modem according to the present 
invention provides local-loop telephone service using radio link between one or more base 
stations and multiple remote subscriber units. In the exemplary embodiment, the radio 
link is described for a base station communicating witii a fixed subscriber unit (FSU), but 
the system is equally applicable to systems including multiple base stations with radio 
Imks to both FSUs and Mobile Subscriber Units (MSUs). Consequently, the remote 
subscriber units are referred to herein as Subscriber Units (SUs). Referring to Figure 1, 
in the exemplary system, the Base Station (BS) 101 provides call connection to the local 
exchange (LE) 103 or other and telephone network switching interface, and includes the 
Radio Carrier Station RCS (104). One or more RCSs 104, 105, 110 connect to the Radio 
Distribution Unit (RDU) 102 through the links 131, 132, 137, 138, 139, and the RDU 
102 in turn interfaces with the LE 103 by transmitting and receiving call set-up, control, 
and information signals through telco links 141, 142, 150. The SUs 116, 119 
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communicate with the RCS 104 through radio links 161, 162, 163, 164, 165. Both the 
RCS and the SUs include CDMA modems which establish and maintain the radio links. 
Alternatively, another embodiment of the invention may include several SUs and a 
'^master" SU which functions in much the same was as the RCS to allow communication 
5 among the SUs. Such embodiment may or may not have connection to a local telephone 
network. 

Although the described embodiment uses different spread-9)ectrum 
bandwidths centered around a carrier for the transmit and receive spread-spectrum 
channels, the present method is readily extended to systems using multiple spread- 

10 spectrum bandwidths for the transmit channels and multiple spread-spectrum bandwidths 
for the receive channels. Alternatively, because spread*spectrum communication systems 
have the inherent feature that one user*s transmission appears as noise to another user^s 
despreading receiver, an embodiment can employ the same spread-^>ectrum channel for 
both the transmit and receive path channels. In other words. Uplink and Downlink 

15 transmissions can occupy the same frequency band. 

The spread binary symbol information is transmitted over the radio links 
161 to 165 using Quadrature Phase Shift Keying (QPSK) modulation with Nyquist Pulse 
Shaping in the present embodiment, although other modulation techniques may be used, 
including, but not limited to. Offset QPSK (CXJPSK) and Mimmum Shift Keymg (MSK). 

20 The RCS and the SUs each contain CDMA modems according to the 

present invention for transmission and reception of telecommunication signals including 
information signals and connection control signals. A CDMA modem which includes an 
embodiment of the present invention includes a modem transmitter having: a code 
generator which provides an associated pilot code signal and which generates a plurality 

25 of message code signals; a spreading circuit which combines each of tiie information 

signals, with a respective one of the message code signals to generate a spread-spectrum 
processed message signal; and a global pilot code generator that provides a global pilot 
code signal to which the message code signals are synchronized. 

The exemplary CDMA modem also includes a modem receiver having 
30 associated pilot code acquisition and tracking logic. The associated pilot code acquisition 
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logic includes an associated pilot code generator and a group of associated pilot code 
correlators for correlating code-phase delayed versions of the associated pilot signal with a 
receive CDM signal to produce a despread associated pilot signal. The code phase of the 
associated pilot signal is changed responsive to an acquisition signal value until a detector 
indicates the presence of the despread associated pilot code signal by changmg the value 
of the acquisition signal. The associated pilot code signal is synchronized to the global 
pilot signal. The associated pilot code tracking logic adjusts the associated pilot code 
signal in phase responsive to the acquisition signal so that the signal power level of the 
despread associated pilot code signal is maximized. Fmally, the CDMA modem receiver 
includes a group of message signal acquisition circuits. Each message signal acquisition 
circuit includes a plurality of receive message signal correlators which corrchite the local 
received message code signal with the CDM signal to produce a respective despread 
received message signal. 

To generate large femilies of neariy mutually orthogonal codes used by the 
CDMA modems, the exemplary modem mcludes a code sequoice generator. The code 
sequences are assigned to a respective logical channel of the spread-spectrum 
communication system, whch includes In-phase (I) and Quadrature (Q) transmission over 
RF communication channels. One set of sequences is used as pilot sequences that are 
transmitted without being modulated by a data signal. The code sequence generator 
circuit mcludes a long code sequence generator mcluding a linear feedback shift register, 
a memory which provides a short, even code sequence, and a pluiaUty of cyclic shift, 
feedforward sections, each of which provides a respective code sequence in the family of 
code sequences. The code sequence generator further includes a group of code sequence 
combiners for combming each generated code sequence witii the short, even code 
sequence to produce a group, or family, of long code sequences havmg relatively low 
mutual correlation. 

BRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 is a block diagram of a code division multiple access 
communication system according to tiie present invention. 
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Figure 2a is a block diagram of a 36 stage linear shift register suitable for 
use with long spreadingcode of the code generator of the present mvention. 

Figure 2b is a block diagram of circuitry which illustrates die feed-forward 
operation of the code generator. 

Figure 2c is a block diagram of an exemplary code generator of the present 
mvention mcluding the circuit for generating spreadingcode sequences from the long 
spreadingcode and the short spreadingcodes. 

Figure 2d is an alternate embodiment of the code generator circuit 
including delays to compensate for electrical circuit delays. 

Figure 3a is a graph of the constellation points of the pilot spreadingcode 

QPSK signal. 

Figure 3b is a graph of the constellation points of the message channel 
QPSK signal. . 

Figure 3c is a block diagram of exemplary circuitry which implements the 
method of tracking the received spreadingcode phase of the present invention. 

Figure 4 is a block diagram of the tracking circuit that tracks the median of 
die received multipath signal components. 

Figure 5a is a block diagram of die tracking circuit diat tracks the centroid 
of the received multipath signal components. 

Figure 5b is a block digram of the Adaptive Vector Correlator. 

Figure 6 is a block diagram of exemplary circuitry which implements the 
acquisition decision mediod of die correct spreading code phase of die received pilot code 
of die present invention. 

Figure 7 is a block diagram of an exemplary pilot rake filter which includes 
the tracking circuit and digital phase locked loop for despreadmg the pilot q)readingcode, 
and generator of the derotation factors of the present invention. 
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Figure 8a is a block diagram of an exemplary adaptive vector correlator 
and matched filter for despreading and combining the muldpath components of the present 
invention. 

Figure 8b is a block diagram of an alternative implementation of the 
adaptive vector correlator and adaptive matched filter for (te^reading and combining the 
multipath components of the present invention. 

Figure 8c is a block diagram of an alternative embodiment of the adaptive 
vector correlator and adaptive matched filter for despreading and combining the multipath 
components of the present invention. 

Figure 8d is a block diagram of the Adaptive Matched Filter of one 
embodiment of the present invention. 

Figure 9 is a block diagram of the elements of an ex^plary radio carrier 
station (RCS) of the present invention. 

Figure 10 is a block diagram of the elements of an exemplary modem 
interface unit (Mill) of the RCS shown in Figure 9. 

Figure 11 is a high level block diagram showing the transmit, receive, 
control, and code generation circuitry of the CDMA modem. 

Figure 12 is a block diagram of the transmit section of the CDMA modem. 

Figure 13 is a block diagram of an exemplary modem input signal receiver. 

Figure 14 is a block diagram of an exemplary convolutional encoder as 
used in the present invention. 

Figure IS is a block diagram of the receive section of the CDMA modem. 

Figure 16 is a block diagram of an exemplary adaptive matdied filter as 
used in the CDMA modem receive section. 

Figure 17 is a block diagram of an exemplary pilot rake as used in the 
CDMA modem receive section. 

Figure 18 is a block diagram of an exemplary auxiliary pilot rake as used 
in the CDMA modem receive section. 
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DESCRIPTION OF THE EXEMPLARY EMBODIMENT 

Referring to Fig. 1, the radio links 161 to 165 incorporate Broadband Code 
Division Multiple Access (B-CDMA™) as the mode of transmission in both the Uplink 
and Downlink directions. CDMA (also known as Spread Spectrum) communication 
techniques used in multiple access systems are well-known. The described exemplary 
system uses tiie Direct Sequence (DS) spreading technique. In each modem, one or more 
CDMA modulators performs the spread-spectmm ^reading code sequence generationin 
addition, the modems generate, for example, a pseudonoise (PN) spreading sequence; and 
pefrorm complex DS modulation to produce quadrature phase shift keying (QPSK) signals 
for the In-phase (I) and Quadrature (Q) channels. Pilot signals are generated and 
transmitted witii die modulated signals. The pilot signals of tiie present embodunent are 
spreading codes which are not modulated by data. TTie pilot signals are used for system 
synchronization, carrier phase recovery, and for estimating die impulse response of the 
radio channel. Each SU includes a single pilot generator and at least one CDMA 
modulator and demodulator, called a CDMA modem. Each RCS 104, 105, 110 has a 
single pilot generator plus sufficient CDMA modulators and demodulators for all die 
logical channels in use by all SUs. 

The CDMA demodulator de^reads die signal, witii appropriate processing 
to combat or exploit multipadi propagation effects. Parameters concerning the received 
power level are used to generate the Automatic Power Control (APC) information which, 
in turn, is transmitted to tiie otiier end (i.e. from die SU to tiie RCS or from tiie RCS to 
tfie SU). The APC information is used to control transmit power of die automatic 
forward power control (AFPC) and automatic reverse power control (ARPC) Imks. In 
addition, each RCS 104, 105 and 110 may perform Maintenance Power Control (MPC), 
in a manner similar to APC, to adjust die initial transmit power of each SU 1 1 1 , 1 12, 
115, 117 and 118. 

Diversity combining at die radio antennas of die RCS 104, 105 and 110 is 
not necessary because CDMA has inherent frequency diversity due to the spread 
bandwiddi. Receivers may include Adaptive Matched Rlters (AMFs) (not shown in 
Figure 1), however, which combine die multipatii signals. In die exemplary embodiment, 
AMFs perform Maximal Ratio Combining. 
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Logical Communication Channels 

A 'channer of the prior art is usually regarded as a communicadons path 
which is part of an interface and which can be distinguished from odier paths of that 
interface without regard to its content. In the case of CDMA, however, sq>arate 
communications paths axe distinguished only by their content. The term Mogical channel' 
is used to distinguish the separate data streams, which are logically equivalent to channels 
in the conventional sense. All logical channels and sub-channels of the present invention 
are mapped to a common 64 kilo-symbols per second (ksym/s) QPSK stream. Some 
channels are synchronized to associated pilot codes which are generated in the same way 
and perform much the same function as the system Global Pilot Code. TTie system pilot 
signals are not, however, considered logical channels. 

Several logical communication channels are used over the RF 
communication link between the RCS and SU. Each lo^cal conununication channel has 
eitfier a fixed, pre-determined spreading code or a dynamically assigned spreading code. 
For both pre-determined and assigned codes, the code phase is in syndironism with the 
Pilot Code. Logical communication chaimels are divided into two groups: the Global 
Channel (GC) group includes those channels which are either transmitted from the base 
station RCS to all the remote SUs or from any SU to die RCS of the base station 
regardless of the SU's identity. These chatmels contain for all users and include the 
channels used by SUs to gain access to message communication channels. Channels in 
the Assigned Channels (AC) group are those channels which are dedicated to 
communication between the RCS and a particular SU. 

The Global Channels (GQ group provides for 1) Broadcast logical 
channels, which provide point to multipoint services for broadcasting messages to all SUs 
and paging messages to SUs; and 2) Access Control logical channels which provide point- 
to-point services on global channels for SUs to access the system and obtain assigned 
channels. 

An Assigned Channel (AC) group contains the logical channels that control 
a single telecommunication connection between the RCS and a SU. The functions 
developed when an AC group is formed consists of a pair of power control logical 
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message chamiels for each of the Uplink and Downlink connections, and depending on the 
type of connection, one or more pairs of traffic channels. The Bearer Control fiincdon 
performs the required forward error control, bearer rate modification, and encryption 
functions. The logical channels which constitute the BC and AC groups are summarired 
5 below in Table 1. 



Table 1 : Logical Channels and sub-channels of the B-CDMA Air Interface 



Channel 
name 


Abbr. 


Brief 

Description 


Diiectio 
n 

(forward 
or 

reverse) 


Bit 
rate 


Max 
BER 


Power 
level 


Pilot 


uioDai (jnannels 




hast 

Broadcas 
t 

Channel 


hBCH 


Broadcasts 
fast- 

chan^g 

system 

information 


F 


16 

kbit/ 
s 


le-4 


Fixed 


GLPT 


Slow 

Broadcas 

t 

Channel 


SBCH 


Broadcasts 
paging 
messages to 
FSUs and 
slow- 
changing 
system 
information 


F 


16 

kbit/ 
s 


le-7 


Fixed 


GLPT 


Access 

Channel 

s 


AXCH( 
i) 


For initial 
access 
attempts by 
FSUs 


R 


32 

kbit/ 

s 


le-7 


Controlled 
byAPC 


LAXPT 
(0 


Control 
Channel 
s 


CTCH( 
i) 


For granting 
access 


F 


32 

kbit/ 

s 


le^7 


Fixed 


GLPT 


Assigned Channels 




16 kbit/s 
POTS 


TRCH 
/16 


General 
POTS use 


F/R 


\6 

kbit/ 
s 


le-4 


Controlled 
byAPC 


F-GLPT 
R-ASPT 


32 kbit/s 
POTS 


TRCH 
132 


General 
POTS use 


F/R 


32 

kbit/ 

s 


le-4 


Controlled 
byAPC 


F-GLPT 
R-ASPT 


64 kbit/s 
POTTS 


TRCH 
/64N 


POTS use 
for in-band 
modems/£ax 


F/R 


64 

kbit/ 

s 


le-4 


Controlled 
byAPC 


F-GLPT 
R-ASPT 


Traffic 
channel 


TRCH 
/64L 


ISDNB 
channel or 


F/R 


kbit/ 


le-7 


Controlled 
byAPC 


F-GLPT 
R-ASPT 
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@64 
kbit/s- 
low 
BER 




LL 




s 








D 

channel 


TRCH 
/loL 


ISDND 
channel 


F/R 


16 

Kbit/ 
S 


le-7 


Controlled 
by APC 


F-GLPT 
R-ASPT 


Order 

wire 

channel 


OW 


assigned 
signaling 
channel 


F/R 


32 

kbit/ 

s 


le-7 


Controlled 
by APC 


F^LPT 
R-ASPT 


APC 
channel 


APC 


carries APC 
commands 


F/R 


64 

kbit/ 
s 


2e-l 


Controlled 
by APC 


F-GLPT 
R-ASPT 



The APC data is sent at 64 kbit/sec. The APC logical channel is not PEC 
coded to avoid delay and is transmitted at a low power level to minimize capacity used for 
APC- Alternatively, the APC and order wire (OW) data may be separately modulated 
using complex spreading code sequences, or they may be time division multilplexed with 
a 16 kbit/s traffic channel. 

Hie Spreading Codes 

The CDMA code generators used to encode the logical channels of the 
present invention employ Linear Shift Registers (LSRs) with feedback logic which is a 
method well known in the art. The code generators of the present embodiment of the 
invention generate 64 synchronous unique sequences. Each RF communicadon channel 
uses a pair of these sequences for complex spreading (in-i)hase and quadrature) of the 
logical channels, so the generator gives 32 complex q>reading sequences. The sequraces 
are generated by a single seed which is initially loaded into a shift register circuit. 

The Generation of Spreading Code Sequences and Seed Selection 

The spreading code period of the present invention is defined as an integer 
multiple of the symbol duration, and the beginning of the code period is also the 
beginning of the symbol. The relation between bandwidths and the symbol lengths 
chosen for the exemplary embodunent of the present invention is: 
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BW (MHZ) L(chips/symbol) 

7 91 

10 130 

10.5 133 

5 14 182 

15 195 



The spreading code length is also a multiple of 64 and of 96 for ISDN 
frame support. The spreading code is a sequence of symbols, called chips or chip values. 
The general methods of generating pseudorandom sequences using Galois Field 

10 mathematics is known to those skilled in the art; hoever, the inventor has derived a 

unique set, or family, of code sequences for the present invention. First, the length of the 
linear feedback shift register to generate a code sequence is chosen, and the initial value 
of the register is called a "seed". Second, the constraint is imposed that no code sequence 
generated by a code seed can be a cyclic shift of another code sequence generated by the 

15 same code seed. Fmally, no code sequence generated from one seed can be a cyclic shift 
of a code sequence generated by another seed. 

The inventor has determined that the spreading code length of chip values 
of the present invention is: 

128 X 233415 = 29877120 (1) 

20 The spreading codes are generated by combining a linear sequence of 

period 233415 and a nonlinear sequence of period 128 

The nonlinear sequence of length 128 is implemented as a fixed sequence 
loaded into a shift register with a feed-back connection. TTie fixed sequence can be 
generated by an m-sequence of length 127 padded with an extra logic 0, 1, or random 
25 value as is well known in the art. 

The linear sequence of length L=233415 is generated using a linear 
feedback shift register (LFSR) circuit with 36 stages. The feedback connections 
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correspond to a irreducible polynomial h(n) of degree 36. The polynomial h(x) chosen by 
the inventor for the exemplary embodiment of the present invention is 

h(x) = + x'" + + + + + + + x^^ + x" 

+ x'* + x" + x" + x" + x" + x' + X* + x^ + x^ + x^ + 1 (2) 

A group of "seed* values for a LFSR rq)resenting the polynomial h(x) of 
equation (2) which generates code sequences that are nearly orthogonal with each other is 
determined. The first requirement of the seed values is that the seed values do not 
generate two code sequences which are simply cyclic shifts of each other. 

The present invention includes a method to increase the number of 
available seeds for use in a CDMA communication system by recognizing that certain 
cyclic shifts of the previously determined code sequences may be used simultaneously. 
The round trip delay for the cell sizes and bandwidths of the present invention are less 
than 3000 chips. In one embodiment of the present invention, sufficiendy separated cyclic 
shifts of a sequence can be used withm the same cell without causing ambiguity for a 
receiver attempting to determine the code sequence. This method enlarges the set of 
sequences available for use. 

By implementing the tests previously described, a total of 3879 primary 
seeds were determined by the inventor through numerical computation. These seeds are 
given mathematically as 

d" modulo h(x) (3) 

where 3879 values of n are listed in the ^pendix. widi d == (00,.. .00111). 

When all primary seeds are known, all secondary seeds of the present 
mvention are derived from the primary seeds by shifting them multiples of 4095 chips 
modulo h(x). Once a family of seed values is determined, these values are stored m 
memory and assigned to logical channels as necessary. Once assigned, the initial seed 
value is simply loaded into LFSR to produce the required spreading code sequence 
associated with the seed value. 

Epodi and Sub-epoch Structures 
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The long complex spreading codes used for the system of the current 
invention have a number of chips after which the code rq)eats. The repetition period of 
the spreading sequence is called an epoch. To map the logical channels to CDMA 
spreading codes, the present invention uses an Epoch and Sub-epoch structure. The code 
period for the CDMA spreading code to modulate logical channels is 29877120 
chips/code period which is the same number of chips for all bandwidths. The code period 
is the epoch of the present invention, and the Table 2 defines the epoch duration for the 
supported chip rates. In addition, two sub-epochs are defined over the spreadmg code 
epoch and are 233415 chips and 128 chips long. 

The 233415 chip sub-epoch is referred to as a long sub-epoch, and is used 
for synchronizing events on the RF communication interface such as encryption key 
switching and changing from global to assigned codes. The 128 chip short q)och is 
defined for use as an additional timing reference. The highest symbol rate used with a 
single CDMA code is 64 ksym/sec. There is always an integer number of chips in a 
symbol duration for the supported symbol rates 64, 32, 16, and 8 ksym/s. 



Table 2 Bandwidths, Chip Rates, and Epochs 



Bandwidth 
(MHz) 


Chip Rate, 
Complex 
(Mchip/sec) 


number of 
chips in a 
64 kbit/sec 
symbol 


128dup 
sub-qx)ch 
duration* 
(us) 


233415 chip 

SUb-^KX^ 

duration* 
(ms) 


Epoch 
duration 
(sec) 


7 


5.824 


91 


21.978 


40.078 


5.130 


10 


8.320 


130 


15.385 


28.055 


3.591 


10.5 


8.512 


133 


15.038 


27.422 


3.510 


14 


11.648 


182 


10.989 


20.039 


2.565 


15 


12.480 


195 


10.256 


18.703 


2.394 



* numbers in these columns are rounded to 5 digits. 

Cyclic sequences of the prior art are generated using linear feedback shift 



register (LFSR) circuits. This method, however, does not generate sequences of even 
length. One embodiment of the spreading code sequence generator using the code seeds 
generated previously is shown in Figure 2a, Figure 2b, and Figure 2c. The exemplary 
system uses a 36 stage LFSR 201 to generate a sequence of period 
N' =233415 =3^x5x7x13x19, which is Co in Figure 2a. In the Figures 2a, 2b, and 2c the 
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symbol © represents a binary addition (EXCLUSIVE-OR), A sequence generator 
designed as above generates the in-phase and quadrature parts of a set of complex 
sequences. The tap connections and initial state of the 36 stage LFSR determine the 
sequence generated by this circuit. The tap coefficients of the 36 stage LFSR are 
determined such that the resulting sequences have the period 23341S. Note that the t^ 
connections shown in Figure 2a corre^nd to the polynomial given in equation (2). Each 
resultuig sequence is tiien overlaid by binary addition witii the 128 lengtii sequence C* to 
obtain die epoch period 29877120. 

Figure 2b shows a Feed Forward (FF) circuit 202 which is used in die code 
generator. The signal X[n-1] is ou^ut of die chip delay 211, and the input of the chip 
delay 21 1 is X[n]. The code chip C[n] is formed by die logical adder 212 from the input 
X[n] and X[n-1]. Figure 2c diows the complete spreading code generator. From the 
LFSR 201, output signals go through a chain of up to 63 single stage FFs 203 cascaded as 
shown. The output of each FF is overlaid with the short, even code sequence C- which 
has a period of 128 =2^. die short code sequence C* is stored in code memory 222 and 
exhibits spectral characteristics of a pseudorandom sequence to obtain the epoch 
N=29877120 when combined witii the sequences provided by the FFs 203. This 
sequence of 128 is determined by using an m-sequence (FN sequence) of lengdi 127=2^ - 
1 and adding a bit-value, such as logic 0, to the sequence to increase the lengdi to 128 
chips. The even code sequence C* is input to the even code shift register 221, which is a 
cyclic register, that continually ou^uts the sequence. The short sequence is then 
combined widi die long sequence using an EXCLUSIVE-OR operation 213, 214, 220. 

As shown in Figure 2c, up to 63 spreading code sequences Co through C& 
are generated by tapping die output signals of FFs 203 and logically adding the short 
sequence C- in a binary adders 213, 214, and 220, for example. One skilled in die art 
would realize diat the implementation of the FF 203 create a cumulative delay effect for 
the code sequences produced at each FF stage in die chain. This delay is due to the 
nonzero electrical delay in the electronic components of the implementation. The timing 
problems associated widi the delay can be mitigated by inserting additional delay elements 
into die FF chain. An exemplary FF chain widi additional delay elements is shown in 
Rgure 2d. 
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The code-generators in the exemplary system are configured to generate 
either global codes, or assigned codes. Global codes are CDNfA codes that can be 
received or transmitted by all users of the system. Assigned codes are CDMA codes that 
are allocated for a particular connection. When a family of sequences is generated from 
5 the same generator as described, only the seed of the 36 stage LFSR is qiedfied. 
Sequences for all the global codes, are generated using the same LFSR circuit. 
Therefore, once an SU has synchronized to the Global pilot signal from an RCS and 
knows the seed for the LFSR circuit for the Global Channel codes, it can generate not 
only the pilot sequence but also all other global codes used by the RCS. 

10 The signal that is upconverted to RF is generated as follows. The 

spreading sequences produced by the above shift register circuits are converted to an 
antipodal sequence (0 maps into +1,1 maps into -1). The Logical channels are initially 
converted to QPSK signals, which are mapped as constellation points as is well known in 
the art. The In-phase and Quadrature charmels of each QPSK signal form the real and 

15 imaginary parts of the complex data value. Similarly, two ^reading codes are used to 
form complex spreading chip values. The complex data and complex spreading code are 
multiplied to produce a spread-spectrum data signal. Similarly, for despreading, the 
received complex data is correlated with the conjugate of the complex spreading code to 
recover the data signal. 

20 Short Codes 

Short codes are used for the initial ramp-up process when an SU accesses 
an RCS. The period of the short codes is equal to the symbol duration and the start of 
each period is aligned with a symbol boundary. Both the SUs and the RCS derive ±e real 
and imaginary parts of the short codes from the last eight feed-forward sections of the 
25 sequence generator to produce the global codes for tiiat cell. 

The signals represented by these short codes are known as Short Access 
Channel pilots (SAXPTs) 

Mapping of Logical Channels to Spreading Codes 

The exact relationship between the spreading code sequences and the 
30 CDMA logical channels and pilot signals is documented in Table 3a and Table 3b. Those 
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signal names ending in *-CH' correspond to logical channels. Those signal names encfing 
in '-PT' correspond to pilot signals, which are described in detail below. 



Table 3a: Spreading code sequences and global CDMA codes 



Sequence 


(^ladrature 


Logical Channel or 


Direction 




Pilot Signal 




Co 


I 


FBCH 


Forward (F) 


Ci 


Q 


FBCH 


F 


C2©C* 


I 


GLPT 


F 


G©C* 


Q 


GLPT 


F 


C4©C* 


I 


SBCH 


F 


Csec* 


Q 


SBCH 


F 


C6®C* 


I 


CrCH(O) 


F 


CtSC* 


Q 


CTCH (0) 


F 


c«®c* 


I 


APCH(l) 


F 


C9©C* 


Q 


APCH (1) 


F 


Ck)©C« 


I 


CTCH (1) 


F 


Cu©C» 


Q 


CTCH(l) 


F 


Cl2©C« 


I 


APCH(l) 


F 


Cb©C« 


Q 


APCH (1) 


F 


Cl4©C« 


I 


CTCH (2) 


F 


Cl5©C» 


Q 


CTCH (2) 


F 


Cifi®C* 


I 


APCH (2) 


F 


Cl7©C' 


Q 


APCH (2) 


F 


Cl8©C' 


I 


CTCH (3) 


F 


Cl9©C* 


Q 


CTCH (3) 


F 




1 




r 


C2J©C' 


Q 


APCH (3) 


F 


Cr©C- 


I 


reserved 




Cj3©C» 


Q 


reserved 




* • • • 


« • • • 


• * • • 


» • • • 


• • • • 




• • • • 


« • • * 


C«©C' 


I 


reserved 




C4J©C- 


Q 


reserved 




C42©C» 


I 


AXCH(3) 


Reverse (R) 


C43©C« . 


Q 


AXCH(3) 


R 
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C44©C' 


I 


LAXPT(3) 
SAXPT(3) seed 


R 


C4S©C« 


Q 


LAXPTO) 
SAXPT(3) seed 


R 


C46©C« 


I 


AXCH(2) 


R 


C47©C- 


Q 


AXCH(2) 


R 


C48©0 


I 


LAXPT(2) 
SAXPT(2) seed 


R 


C49®C» 


Q 


LAXPT(2) 
SAXPT(2) seed 


R 


C3O0C' 


I 


AXCHd) 


R 




Q 


AXCHd) 


R 


CS2©C» 


I 


LAXPT(1) 
SAXPTd) seed 


R 




Q 


LAXPT(1) 
SAXPT(1) seed 


R 


C54©C« 


I 


AXCH(0) 


R 


Css©C' 


Q 


AXCH(0) 


R 


C360C* 


I 


LAXPT(0) 
SAXPT(0) seed 


R 


CS7©C' 


Q 


LAXPT(0) 
SAXPT(0) seed 


R 


C58©C» 


I 


IDLE 




C59®C- 


Q 


IDLE 




C60®C« 


I 


AUX 


R 


C61©C. 


Q 


AUX 


R 


C62©C. 


I 


reserved 




C63©C- 


Q 


reserved 





Table 3b: Spreading code sequences and assigned CDMA codes. 



Sequence 


Quadrature 


Logical Channel or 
Pilot Signal 


Direction 


C(i©C» 


I 


ASPT 


Reverse (R) 


Ci©C' 


Q 


ASPT 


R 


CaffiC- 


I 


APCH 


R 


Cj©C' 


Q 


APCH 


R 
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I 


OWCH 


R 


C3©C' 


Q 


OWCH 


R 


C6©C» 


I 


TRCH(0) 


R 


CTffiC* 


Q 


TRCH(0) 


R 


C8©C» 


I 


TRCH(l) 


R 


Cs©C 


Q 


TRCH(l) 


R 


Cio®C« 


I 


TRCH(2) 


R 


Cu®C' 


Q 


TRCH(2) 


R 


CnffiC' 


I 


TRCH(3) 


R 


CoSO 


Q 


TRCH(3) 


R 


Cm©C. 


I 


reserved 


- 


Cis©C' 


Q 


reserved 


- 


• • • • 


• • • • 


• • • • 


• • • « 


• • • • 


• « • • 


• • • * 


* • • • 


C44®C» 


I 


reserved 


- 


C45®C. 


Q 


reserved 


- 


C46©C. 


I 


TRCH(3) 


Forward (F) 


C47®C' 


Q 


TRCH(3) 


F 


C«©C' 


I 


TRCH(2) 


F 


C49©C« 


Q 


TRCH(2) 


F 


C«©C' 


I 


TRCH(l) 


F 


Csi©C» 


Q 


TRCH(l) 


F 


C52©C« 


I 


TRCH(0) 


F 


CS3©C' 


Q 


TRCH(0) 


F 


Cs4®C' 


I 


OWCH 


F 


C55©C' 


Q 


OWCH 


F 


CseffiC' 


I 


APCH 


F 


C57©C' 


Q 


APCH 


F 




I 


IDLE 




C39©C' 


Q 


IDLE 




C«o©C' 


I 


reserved 




C61©C« 


Q 


reserved 




C«2©C- 


I 


reserved 




C(B©C« 


Q 


reserved 
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Pilot Signals 

As described above, the pilot signals are used for synchronizatioii. carrier phase 
recovery, and for estimating the impulse response of the radio channel. The RCS 104 
transmits a forward link pilot carrier reference as a complex pUot code sequence to 
provide a time and phase reference for all SUs 111. 112, 115, 117 and 118 in its service 
area. The power level of the Global Pilot (GLPT) signal is set to provide adequate 
coverage over the whole RCS service area, which area depends on the ceU size. With 
only one pilot signal in the forward link, the reduction in system capacity due to the pUot 
energy is negh'gible. 

Each of the SUs 111, 112. 115. 117 and 118 transmits a pilot carrier reference as 
a quadrature modulated (complex-valued) pilot spreading code sequence to provide time 
and phase reference to the RCS for the reverse link. The pilot signal transmitted by the 
SU of one embodiment of the invention is 6 dB lower than the power of the 32 kbit/s 
POTS (plain old telephone service) traffic channel. The reverse pilot channel is subject to 
AFC. The reverse link pilot associated with a particular connection is called the Assigned 
Pilot (ASPT). In addition, there are pilot signals associated with access channels, and 
these are called the Long Access Channel Pilots (LAXFTs). Short access channel pilots 
(SAXPTs) are also associated with the access channels and used for spreading code 
acquisition and initial power ramp-up. 

All pilot signals are formed from complex codes, as defined below: 

GLPT (forward) = {CzeC-) + j.(C3©C.)} . {(±1) + j.(0)} 

{ Complex Code } . { Carrier } 

The complex pilot signals are de-spread by multiplication with conjugate spreading 
codes: {(CjeC*) - J.(Cs©C-)}. By contrast, traffic channels are of the form: 

TRCHa(forward/reverse) = {(Ci®C«) + j.(Ci®C»)} . { (±1) + j(±i) } 

{ Complex Codes }.{ Data Symbol} 

which thus form a constellation set at radians with respect to the pilot signal 
constellations. 
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The GLPT constellation is shown in Figure 3a, and the TRCHn traffic channel 
constellation is shown in Figure 3b. 

Logical Channel Assignment of the FBCH, SBCH, and TVaffic Oiannels 

The fast broadcast channel (FBCH) is a global forward link channel used to 
broadcast dynamic information about the availabili^ of services and access channels 
(AXCHs). The messages are sent continuously, and each message lasts approximately 1 
ms. The FBCH message is 16 bits long, repeated continuwisly, and epoch aligned. The 
FBCH is formatted as defined in Table 4. 

Table 4: FBCH format 



Bit 


Definition 


0 


Traffic Light 0 


1 


Traffic Ught 1 


2 


Traffic Ught 2 


3 


Traffic Ught 3 


Tt 


service indicator bits 


8 


Traffic Ught 0 


9 


Traffic Ught 1 


10 


Traffic Ught 2 


11 


Traffic Ught 3 


12-15 


service mdicator bits 



For die FBCH, bit 0 is transmitted first. A traffic Ught corresponds to an Access 
Channel (AXCH) and indicates whetiier die particular access channel is currentiy in use 
(red) or not in use (green). A logic '1' indicates that the traffic light is green, and a logic 
♦0* indicates die traffic light is red. The values of die traffic Ught bits may change from 
octet to octet, and each 16 bit message contains distinct service indicator bits whidi 
describe which types of service are available for die AXCHs. 

One embodiment of die present invention uses service indicator bits as 
follows to indicate die availabUity of services or AXCHs. The service indicator bits 
{4,5,6,7,12,13,14,15} are interpreted as an unsigned bmary number, widi bit 4 as die 
MSB and bit 15 as die LSB. Each service type increment has an associated nommal 
measure of die capacity required, and die FBCH continuously broadcasts die available 
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capacity. This is scaled to have a maximum value equivalent to the largest single service 
increment possible. When an SU requires a new service or an increase in the number of 
bearers), it compares the capacity required to that indicated by the FBCH, and then 
considers itself blocked if the capacity is not available. The FBCH and the traffic 
channels are aligned to the qxx:h. 

Slow Broa<fcast Information frames contain system or other general 
mformation that is available to all SUs, and Paging Information frames contam 
information about call requests for particuhr SUs. Slow Broadcast Information frames 
and Paging Information frames are multiplexed togetiier on a single logical channel which 
forms die Slow Broadcast Channel (SBCH). As previously defined, the code epoch is a 
sequence of 29 877 20 chips having an epoch duration which is a function of die chip rate 
defined in Table 5 below. In order to facilitate power saving, dte channel is divided into 
N "Sleep" Cycles, and each Cycle is subdivided into M Slots, which are 19 ms long, 
except for 10.5 Mhz bandwidth which has slots of 18 ms. 



Table 5: SBCH Channel Format Outline 



Bandwidtii 
(MHz) 


Spreading 
Code Rate 

(MHz) 


Epoch 
Length 

(ms) 


Cycles/ 
Epoch 
N 


Cycle 
Length 
(ms) 


Slots/ 
Cycle 
M 


Slot 
Lengtii 
(ms) 


7.0 


5.824 


5130 


5 


1026 


54 


19 


10.0 


8.320 


3591 


3 


1197 


63 


19 


10.5 


8.512 


3510 


3 


1170 


65 


18 


"14:0 


11.648 


2565 


3 


855 


45 


19 


15.0 


12.480 


2394 


2 


1197 


63 


19 



Sleep Cycle Slot #1 is always used for slow broadcast information. Slots 
#2 to #M-1 arc used for paging groups unless extended slow broadcast information is 
inserted. The pattern of cycles and slots in one embodiment of the present mvention rur 
continuously at 16 kbit/s. 



Witiiin each Sleep Cycle die SU may power-up the receiver and re-acquire 
pilot code to achieve carrier lock to a sufficient precision for satisfactory demodulation 
and Viterbi decoding. This settiing time may be up to 3 Slots m duration. For example, 
. an SU assigned to Slot #7 may power up tiie Receiver at die start of Slot #4. Having 
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monitored its Slot tlie SU either recognizes its Paging Address and initiates an access 
request, or fails to recognize its Paging Address in which case it reverts to the Sleep 
mode. 

Spreading code Ticking and AMF Detection in Multipath Ciiannels 
Spreading code Traddng 

Three CDMA spreading code tracking methods in multipath &ding 
environments are described which track the code phase of a received multipafih ^lead- 
spectrum signal. The first method uses the prior art tracking circuit which simply tracks 
the spreading code phase of the detector having the hi^est output signal value, the second 
method uses a tracking circuit diat tracks the median value of the code phase of the group 
of multipath signals, and the third method of the present mvention, is the centroid 
tracking circuit which tracks the code-phase of an optimized, least mean squared weighted 
average of the multipath signal components. The following describes die algorithms by 
which the spreading code phase of the received CDMA signal is tracked. 

A tracking circuit has operating characteristics that reveal the relationship 
between the time error and the control voltage that drives a Voltage Controlled Oscillator 
(VCO) of a spreading code phase tracking circuit. When there is a positive timing error, 
the exemplary tracking circuit generates a negative control voltage to offset the timing 
error. When there is a negative timing error, the exemplary tracking circuit gaierates a 
positive control voltage to offset the timing error. When the tracking circuit generates a 
zero value, this value corresponds to the perfect time alignment called die 'lock-point'. 
Figure 3c shows the basic tracking circuit. Received signal r(t) is i5>plied to matched 
filter 301, which correlates r(t) wiUi a local code-sequence c(t) generated by Code 
Generator 303. The output signal of the matched filter x(t) is sampled at the sampler 302 
to produce samples x[nT\ and x[nT + T/2]. The samples x[nTl and x[nT + T/2] are used 
by a tracking circuit 304 to determine if die phase of the spreading code c(t) of the code 
generator 303 is correct. The tracking circuit 304 produces an error signal e(t) as an 
input to the code generator 303. The code generator 303 uses this signal e(t) as an input 
signal to adjust the code-phase it generates. 
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In a CDMA system, the signal transmitted by the reference user is written 
in the low-pass r^resentation as 

<')='Zc,Pr,it-kT,) (4) 

where Ck represents the spreading code coefficients. Pitfy represents the spreading code 
5 chip waveform, and Tc is the chip duration. Assuming that the reference user is not 

transmitting data, only the spreading code modulates the carrier. Referring to Figure 3, 
the received signal is 

r(/) = f;a,5(/-rj (5) 

Here, ai is due to fading effect of the multipath channel on the i-th path and 
10 Ti is the random time delay associated with the same path. The receiver passes the 

received signal through a matched filter, which is implemented as a correlation receiver 
and is described below. This operation is done in two steps: first die signal is passed 
tixrough a chip matched filter and sampled to recover the spreading code chip values, then 
tiiis chip sequence is correlated witii the locally generated code sequence. 

Figure 3c shows tiie chip matched filter 301, matched to tiie chip waveform 
Prcft), and Uie sampler 302. The signal x(t) at tiie output terminal of die chip matched 
filter is 

^W = i;Z^A^^-r,-^7;) (6) 

where 

20 g(t) = PTc(t)*hR(t) (7) 

Here, hR(t) is tiie impulse response of die chip matched filter and *** denotes convolution. 
The order of the summations, can be rewritten as: 

<t)=±cj{t-kr,) (8) 

where 
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/W = Z«.^^-^/) (9) 

In the multipath channel described above, the sampler samples the output 
signal of the matched filter to produce x(nT) at the maximum power level points of g(t). 
In practice, however, the waveform g(t) is often severely distorted because of the effect of 
the multipath signal reception, and a perfect time alignment of the signals is not available. 

When the multipath in the channel is negligible and a perfect estimate of 
the timing is available, i.e., ai=l, ti=0, and ai=0, i=2,...,M, the received signal is r(t) 
= s(t). Then, with this ideal channel model, the output of the chip matched filter 
becomes 

^^)^jlc,g{t-kT,) (10) 

*=-eO 

When there is multipath fading, however, the received spreading code chip 
value waveform is distorted, and has a number of local maxima that can change from one 
sampling interval to another depending on the channel characteristics. 

For multipath folding channels with quickly changing channel 
characteristics, it is not practical to try to locate the maximum of the waveform /ft) in 
every chip period mterval. Instead, a time reference can be obtained from the 
characteristics of f(t) that may not change as quickly. Three tracking methods are 
described based on different characteristics of f(t). 

Prior Art Spreading code Tracking Method: 

Prior art tracking methods include a code tracking circuit in which the 
receiver attempts to determine where the maximum matched filter ou^ut value of the chip 
waveform occurs and sample the signal at that pomt In multipath fading channels, 
however, the receiver despreading code waveform can have a number of local maxuna, 
especially in a mobile environment. If /ft; represents die received signal waveform of the 
spreading code chip convolved with the charmel impulse response, the shape of f(t) and 
where its maximum occurs can change ratiier quickly making it impractical to track die 
maximum of f(t). 
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Define x to be the time estimate that the tracking circuit calculates during a 
particular sampling interval. Also, define the following error function 



jfit)dt. M>S (11) 

The tracking circuits of the prior art calculate a value of the input signal that minimizes 
the error e. One can write 

minf = 1-max jf{t)dt (12) 



Assuraing/^'rj has a smoodi shape in the values given, the value of x for 
which /frj is maximum minimizes the error so the tracking circuit tracks the maximum 
point of /ft). 

Median Weighted Value Tracking Method: 

The Median Weighted Tracking Method of one embodiment of the present 
invention, minimizes the absolute weighted error, defined as 

^ = £k-^/('>* (13) 

This tracking mediod calculates the *median' signal value of /ft) by 
collecting information from all paths, where/fz^ is as in equation (9). In a multipatii 
fading environment, die waveform /ft) can have multiple local maxima, but only one 
median. 

To minimizes , the derivative of equation (13) is taken wifli respect to x 
and equated it to zero, which gives 

=r-^('>* (14) 

The value of t that satisfies (14) is called the ♦median* of /ft). Therefore, 
the Median Tracking Method of the present embodiment tracks the median of /ft). Figure 
4 shows an implementation of the tracking circuit based on minimizing the absolute 
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weighted error defined above. The signal x(t) and its one-half chip offset version 
x{t+T/2) are sampled by the analog-to-digital A/D converter 401 at a rate 1/T. The 
following equation determines the operating characteristic of the circuit in Figure 4: 

^^) = Z|/(^"''7'/2)|-|/(r+iir/2)| (15) 

Trackmg the median of a group of multipath signals keeps the received 
energy of the multipath signal components equal on the early and late sides of the median 
point of the correct locally generated ^reading code phase Cn. The tracking circuit 
consists of an A/D converter 401 which samples an input signal x(t) to fonn the half chip 
offset samples. The half chip offset samples are alternatively grouped into even samples 
called an early set of samples x(nT+t) and odd samples called a late set of samples 
x(nT+(T/2)+ t). The first correlation bank ad^tive matched filter 402 multiplies each 
early sample by the spreading code phases c(n+l), c(n+2), c(n+L), where L is 
small compared to the code length and approximately equal to number of chips of delay 
between the earliest and latest multipath signal. The output of each correlator is applied 
to a respective first sum-and-dump bank 404. The magnitudes of the output values of the 
L sum-and-dumps are calculated in the calculator 406 and then summed in a sunmier 408 
to give an output value propordonal to the signal energy in the early multipath signals. 
Similarly, a second correlation bank adaptive matched filter 403 qierates on the late 
samples, using code phases c(n-l), c(n-2), c(n-L), and each ou^ut signal is applied to 
a respective sum-and-dump in an integrator 405. The magnitudes of the L sum-and-dump 
outputs are calculated in calculator 407 and then summed in summer 409 to give a value 
for the late multipatii signal energy. Finally, the subtractor 410 calculates the difference 
and produces error signal e(t) of the early and late signal energy values. 

The tracking circuit adjusts, by means of error signal e(T), die locally 
generated code phases c(t) to cause the difference between the early and late values to 
tend toward 0. 

Centroid Trackmg Method 

Another spreading code trackmg circuit of one embodiment of the present 
invention is called the squared weighted tracking (or centroid) circuit Definmg x to 



SUBSTITUTE SHEET (RULE 26) 



wo 97/02675 



PCTAJS96/11059 



-27- 

denote the time estimate that the tracking circuit calculates, based on some characteristic 
of /ft), the centroid tracking circuit minimizes the squared weighted error defined as 

^ = D"^V(/>/^ (16) 

This function inside the integral has a quadratic form, whidi has a unique 
minimum. The value of x that minimizes e can be found by taking the derivative of the 
above equation witii respect to x and equating to zero, whidi gives 

£(-2/+2r)/(/y/=.0 (17) 
Therefore, tiie value of x tiiat satisfies 

^-^£^('>*==0 (18) 

is the timing estimate tiiat tiie tracking circuit calculates, and is a constant value. 

Based on these observations, a realization of the tracking circuit 
minimizing tiie squared weighted error is shown in Figure 5. The following equation 
determines tiie error signal e(x) of the centroid tracking circuit: 

<r) = Zri^{T-nT/2)\-\f{r'^nT/2)\Uo (19) 

The value tiiat satisfies e(x)=0 is tiie optimized estimate of tiie timing. 

The early and late multipatii signal energy on each side of the centroid 
point are equal. The centroid tracking circuit shown in Figure 5 consists of an A/D 
converter 501 which samples an input signal x(t). as described above wifli reference to 
Fig. 4 to form half chip offset samples. The half chip offset samples arc alternatively 
grouped as an early set of samples x(nT+x) and a late set of samples x(nT+(T/2)+ x). 
The first correlation bank adaptive matched filter 502 multiplies each early sample and 
each late sample by tiie positive spreading code phases c(n+l), c(n+2), c(n+L), 
where L is small compared to the code lengtii and is approximately equal to number of 
chips of delay between tiie eariiest and latest multipatii signal. The ou^ut signal of each 
correlator is applied to a respective one of L sum-and-dump circuits of tiie first sum and 
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dump bank 504. The magnitude value of the output signal produced by each sum-and- 
dump circuit of the sum and dump bank 504 is calculated by the re^>ective calculator in 
the caluiator bank 506 and applied to a corresponding weighting amplifier of the first 
weighting bank 508. The output signal of each weighting amplifier represents the 
weighted signal energy in a muUipath component signal. 

The weighted early multipath signal energy values are summed in sample 
adder 510 to give an output value that is proportional to the signal energy in the group of 
multipath signals corresponding to positive code phases which are the early multipath 
signals. Similarly, a second correlation bank adaptive matched filter 503 operates on the 

early and late samples, using tiie negative spreading code phases c(n-l), c(n-2) c(n- 

L), each output signal is provided to a respective sum-and-dump circuit of discrete 
integrator 505. The magnitude value of the L sum-and-dump ou^ut signals are calculated 
by the respective calculator of calculator bank 507 and then weighted in weighting bank 
509. The weighted late muUipath signal energy values are summed in sample adder 511 
to give an energy value for the group of multipath signals corresponding to the negative 
code phases which are the late multipath signals. Finally, the subtracter 512 calculates 
the difference of the early and late signal energy values to produce error sample value 
e(T). 

The tracking circuit of Figure 5 produces error sigtud e(T) which is used to 
adjust the locally generated code phase c(nT) to keep the weighted average energy m the 
early and late multipath signal groups equal. The embodiment shown uses weighting 
values that increase as the distance from the centroid increases. The signal energy in the 
earliest and latest multipath signals is probably less than the multipath signal values near 
the centroid. Consequently, the difference calculated by the subtracter 512 is more 
sensitive to variations in delay of the earliest and latest multipath signals. 

Quadratic Detector for Trackmg 

In anoUier exemplary tracking metfiod, the tracking circuit adjusts sampling 
phase to be •* optimal" and robust to multipath. If f(t) represent the received signal 
waveform as in equation (9) above. The particular method of optimizing starts with a 
delay locked loop witii an error signal e(T) that drives the loop. The function e(x) 
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desirably has only one zero at t=To where xo is optimal. The optimal form for e(T) has 
the canonical form: 

e(T) = J w(t,T) |f(t)|»dt (20) 



- 00 



where w(t, t) is a weighting function relating f(t) to the error e(T), and the following 
holds 



WW 

e(x+To) = J w(t, T+To) |f(t)|*dt (21) 

It follows from equation (21) that w(t, t) is equivalent to w(t-T). 
Considering the slope M of die error signal in the neighborhood of a lode point xo: 



M 



= ^ U. =- J w*(t-xo) g(t) dt (22) 



where w*(t, x) is the derivative of w(t, t) widi respect to x, and g(t) is the average of 
If(t)ll 

The error e(x) has a deterministic part and a noise part. Let z denote the 
noise component in e(x), then I z 1 ^ is the average noise power in the error function e(x). 
Consequently, the optimal tracking circuit maximizes the ratio: 

F = (23) 

The implementation of the Quadratic Detector is now described. The 
discrete error value e of an error signal e(x) is generated by performing the operation 

e = y^y (24) 

where the vector y represents the received signal components yi, i = 0, 1, ... L-1, as 
shown in Figure 5b. The matrix B is an L by L matrix and the elements are determined 
by calculating values such that the ratio F of equation 23 is maximized. 
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Determining the Minimum Value of L needed: 

The value of L in the previous section determines the minimum nuniber of 
correlators and sum-and-dump elements. L is chosen as small as possible without 
compromising the functionality of the tracking circuit. 

The multipath characteristic of the channel is such that the received chip 
waveform f(t) is spread over QTe seconds, or the multipath components occupy a time 
period of Q chips duration. The value of L chosen is L=Q. Q is found by measuring the 
particular RF channel transmission characteristics to determine the earliest and latest 
multipath component signal propagation delay. QTe is the difference between the earliest 
and latest multipath component arrival time at a receiver. 

The Quadratic Detector described above may be used to implement the 
centroid tracking system described above with reference to Figure 5a- For this 
implementation, the vector y is the output signal of the sum and dump circuits 504: 
y={f(t-LT), f(T-LT+T/2), f(T-(H)T)» • • • f(T). f(T+T/2), f(T+T), • • • f(x+LT)} and 
the matrix B is set fonh in table 6. 



Table 6 B matrix for quadratic form of Centroid Tracking System 
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Adaptive Vector Correlator 

An embodiment of the present invention uses an ad^tive vector correlator 
(AVC) to estimate the channel impulse response and to obtain a reference value for 
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coherent combining of received multipath signal components. The described embodiment 
employs an array of correlators to estimate the complex channel response affecting each 
multipath component, then the receiver compensates for the diannel response and 
coherently combines the received multipath signal components. This approach is referred 
to as maximal ratio combining. 

Referring to Rgure 6. The input signal x(t) to the system is composed of 
interference noise of other message channels, multipadi signals of message channels, 
thermal noise, and multipath signals of the pilot signal. The signal is provided to AVC 
601 which includes a despreading means 602. channel estimation means for estimating die 
channel response 604, correction means for correcting a signal for effects of the channel 
response 603, and adder 605 in tiie present invention. The AVC despreading means 602 
is composed of multiple code correlators, witii each correlator using a different phase of 
the pilot code c(t) provided by die pilot code generator 608. The output of tiiis 
despreading means corresponds to a noise power level if the phase of the local pilot code 
of die despreading means is not in phase widi the input code signal, or it corresponds to a 
received pilot signal power level plus noise power level if tiie input pilot code and locally 
generated pilot code phases are the same. The output signals of the correlators of the 
despreading means corrected for the channel response by the correction means 603 and 
are ^plied to die adder 605 which collects all multipadi pilot signal power. The channel 
response estimation means 604 receives the combined pilot signal and the output signals 
of the despreading means 602. and provides a channel response estimate signal, w(t), to 
die correction means 603 of tiie AVC. and die estimate signal w(t) is also available to die 
adaptive matched filter (AMF) described subsequentiy. The ou^ut signal of die 
despreading means 602 is also provided to die acquisition decision means 606 which 
decides, based on a particular algoridim. such as a sequential probability ratio test 
(SPRT), if die present output levels of the despreading circuits correspond to 
synchronization of die locally generated code to die desired input code phase. If die 
detector finds no synchronization, dien die acquisition decision means sends a control 
signal a(t) to die local pilot code generator 608 to offset its phase by one or more chip 
periods. When synchronization is found, die acquisition decision means informs die 
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tracldng circuit 607, which achieves and maintains a close synchronizadon between the 
received and locally generated code sequences. 

An exemplary implementation of the Pilot AVC used to despread the pilot 
spreading code is shown in Figure 7. Tlie described embodiment assumes that the input 
5 signal x(t) has been sampled with sampling period T to form x(nT+x), and is composed 
of interference noise of other message channels, multipath signals of message channels, 
thermal noise, and multipath signals of the pilot code. The signal x(nT+t) is applied to 
L correlators, where L is the number of code phases over which the uncertainty within the 
multipath signals exists. Each correlator 701, 702, 703 comprises a respective multiplier 

10 704, 705, 706, which multiples the input signal with a particular phase of the Pilot chip 
code signal c((n+i)T), and a sum-and-dump circuit 708, 709, 710. The output signal of 
each multiplier 704, 705, 706 is applied to a respective sum-and dump circuit 708, 709, 
710 to perform discrete integration. Before summing the signal energy contained in the 
outputs of the correlators, the AVC compensates for the chaimel response and the carrier 

13 phase rotation of the different multipath signals. Each output signal of each sum-and- 
dump 708, 709, 710 is multiplied by a derotation phasor [complex conjugate of ep(nT)] 
obtained from the digital phase lock loop (DPLL) 721. TTiis phasor is ^plied to one 
input port of a respective multiplier 714, 715, 716 to account for the phase and frequency 
offset of the carrier signal. The Pilot Rake AMF calculates, complex weighting factors, 

20 wk, k=l, L, for each multipath signal by passing the output of each multiplier 714, 
715, 716 tiirough a low pass filter (LPF) 711, 712, 713. Each despread multipatii signal is 
multiplied by its corresponding weighting factor in a respective multiplier 717, 718, 719. 
The output signals of the multipliers 717, 718, 719 are summed in a master adder 720, 
and the output signal p(nT) of the accumulator 720 consists of the ccunbined despread 

25 multipatii pilot signals in noise. The output si^ p(nT) is also applied to the DPLL 721 
to produce the error signal ep(nT) for tracking of the carrier phase. 

Figures 8a and 8b show alternate embodiments of die AVC which can be 
used for detection and multipath signal component combming. The message signal AVCs 
of Figures 8a and 8b use the weighting factors produced by the Pilot AVC to correct the 
30 message data multipatii signals. The spreading code signal, c(nT) is the spreading 
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sequence used by a particular message channel and is synchronous with the pilot 
spreading code signal. The value L is the number of correlators in the AVC circuit 

The circuit of Figure 8a calculates the decision variable Z which is given 

by 

Z = I; x(/T + r)c(/7) + >f , f x(/T + r)c{(/ + 1)7) 

(25) 

L 

i=\ 

where N is the number of chips in the correlation window. Equivalently, the decision 
statistic is given by 

+ • • • ^x{NT + r)^ y^sc({i + N)t) (26) 

=Z*(*7'_oZM('+*-07') 

The alternative implementation that results from equation (26) is shown in 

Figure 8b. 

Referring to Figure 8a, the input signal x(t) is sampled to fonn x(nT+x), 
and is composed of interference noise of other message channels, multipaA signals of 
message channels, thermal noise, and multipath signals of the pilot code. The signal 
x(nT+T) is applied to L correlators, where L is the number of code phases over which the 
uncertainty within die multipath signals exists. Each correlator 801, 802, 803 comprises 
a multiplier 804, 805, 806, which multiples the input signal by a particular phase of flie 
message channel spreading code signal, and a respective sum-and-dump circuit 808, 809, 
810. The output of each multiplier 804, 805, 806 is applied to a respective sum-and dump 
circuit 808, 809, 810 which performs discrete integration. Before summing the signal 
energy contained in tiie output signals of tiie correlators, the AVC compensates for die 
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different multipath signals. Each despread multipath signal and its corresponding 
weighting fector, which is obtained from the corresponding multipadi weighting factor of 
the pilot AVC, are multiplied by multiplier 817, 818, 819. The ou^ut signals of the 
multipliers 817, 818, 819. The output signals of tiie multipliers 817, 818, 819 are 
5 summed in a master adder 820, and the output signal z(nT) of the accumulator 820 
consists of sampled levels of a despread message signal in noise. 

The alternative embodiment of the mvention includes a new 
implementation of the AVC despreading circuit for the message channels which performs 
the sum-and-dump for each multipath signal component simultaneously. The advantage 

10 of this circuit is that only one sum-and dump circuit and one adder is necessary. 

Referring to Figure 8b, the message code sequence generator 830 provides a message 
code sequence to shift register 831 of length L. The ou^ut signal of each register 832, 
833, 834, 835 of die shift register 831 corresponds to the message code sequence shifted 
in phase by one chip. The output value of each register 832, 833, 834, 835 is multiplied 

15 in multipliers 836, 837, 838, 839 witii the corre^nding weighting factor wk, k=l, L 
obtained from tiie Pilot AVC. The output signals of the L multipliers 836, 837, 838, 839 
are summed by the adding circuit 840. The adding circuit ou^ut signal and the receiver 
input signal x(nT +x) are then multiplied in the multiplier 841 and integrated by the sum- 
and-dump circuit 842 to produce message signal z(nT). 

20 A third embodiment of the adaptive vector correlator is shown in Figure 

8c. This embodiment uses the least mean square (LMS) statistic to implement the vector 
correlator and determines the derotation factors for each multipath component from the 
received multipath signal. The AVC of Figure 8c is similar to the exemplary 
implementation of the Pilot AVC used to despread the pilot spreading code shown in 

25 Figure 7. The digtal phase locked loop 721 is replaced by a phase locked loop 850 
having a voltage controlled oscillator 851, loop filter 852, linuter 853, and imaginary 
component separator 854. The difference between the corrected despread output signal 
dos and an ideal despread output is provided by adder 855, and the difference signal is a 
despread error value ide whidi is further used by the derotation circuits to compensate for 

30 errors in the derotation factors. 
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In a multipath signal environment, the signal energy of a transmitted 
symbol is spread out over the multipath signal components. The advantage of multipath 
signal addition is that a substantial portion of signal energy is recovered in an output 
signal from the AVC. Consequentiy, a detection circuit has an irq)ut signal from the 
AVC with a higher signal-to-noise ratio (SNR), and so can detect the presence of a 
symbol with a lower bit-error ratio (BER). In addition, measuring tiie output of tfie AVC 
is a good indication of the transmit power of the transmitter, and a good measure of the 
system's interference noise. 

Adaptive Matched Filter 

One embodiment of the current invention includes an Adaptive Matched 
Filter (AMF) to optimally combine the multipatii signal components in a received spread 
spectrum message signal. The AMF is a tapped delay line which holds shifted values of 
the sampled message signal and combines these after correcting for the chaimel response. 
The correction for the channel response is done using the channel response estimate 
calculated in the AVC which operates on the Pilot sequence signal. The output signal of 
the AMF is the combination of the multipath components which are summed to give a 
maximum value. This combination corrects for the distortion of multipath signal 
reception. The various message despreading circuits operate on this combined multipath 
component signal from die AMF. 

Figure 8d shows an exemplary embodiment of die AMF. The sampled 
signal from die A/D converter 870 is j^plied to th I^stage delay line 872. Each stage of 
this delay line 872 holds the signal corresponding to a different multipath signal 
component. Correction for the channel response is applied to each delayed signal 
component by multiplying the component in the respective multiplier of multiplier bank 

874 witii the respective weighting factor wi, wa wl from the AVC corresponding to 

the delayed signal component. All weighted signal components are sunmied in the adder 
876 to give die combined multipath component signal y(t). 

The combined multipath component signal y(t) does not include the 
correction due to phase and frequency offset of die carrier signal. The correction for die 
phase and frequency offset of the carrier signal is made to y(t) by multiplying y(t) with 
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carrier phase and frequency correction (derotation phasor) in multiplier878* The phase 
and frequency correction is produced by the AVC as described previously. Figure 8d 
shows the correction before the despreading circuits 880, but alternate embodiments of the 
invention can apply the correction after the despreading circuits. 

The Radio Carrier Station (RCS) 

The Radio Carrier Station (RCS) of the present invention acts as a central 
interface between the SU and the remote processing control network element, such as a 
Radio Distribution Unit (RDU). The interface to the RDU of the exemplary system 
follows the G,704 standard and an interface according to a modified version of DECT 
VS. 1 , but the present invention may support any interface that can exchange call control 
and traffic channels. The RCS receives mformation channels from the RDU including 
call control data, and traffic channel data such as, but not limited to, 32 kb/s ADPCM, 64 
kb/s PCM, and ISDN, as well as system configuration and maintenance data. The RCS 
also terminates the CDMA radio interface bearer channels with SUs, which channels 
include both control data, and traffic channel data. In response to the call control data 
from either the RDU or a SU. the RCS allocates traffic channels to bearer channels on the 
RF communication link and establishes a communication connection between the SU and 
the telephone network through an RDU. 

As shown in Figure 9, the RCS receives call control and message 
information data into the MUXs 905, 906 and 907 through interface lines 901, 902 and 
903. Although El format is shown, other similar telecommunicatioh formats can be 
supported in the same manner as described below. Each MUX provides a connection to 
the Wireless Access Controller (WAC) 920 through the PCM highway 910. While the 
exemplary system shown in Figure 1 uses an El Interface, it is contemplated that other 
types of telephone lines which convey multiple calls may be used, for example, Tl lines 
or lines which interface to a Private Branch Exchange (PBX). 

The Wireless Access Controller (WAC) 920 is the RCS system controller 
which manages call control functions and interconnection of data streams between the 
MUXs 905, 906, 907 and the Modem Interface Units (MIUs) 931, 932, 933. The WAC 
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920 also controls and monitors other RCS elements such as the VDC 940, RF 950, and 

* 

Power Amplifiers 960. 

A low speed bus 912 is connected to the WAC 920 for transferring control 
and status signals between the RF Transmitter/Receiver 950, VDC 940, RF 950 and 
Power Amplifier 960. The control signals are sent from the WAC 920 to enable or 
disable the RF Transmitters/Receiver 950 or Power amplifier 960, and the status signals 
are sent from the RF Transmitters/Receiver 950 or Power amplifier 960 to monitor the 
presence of a fault condition. 

The exemplary RCS contains at least one MIU 931, which is shown in 
Figure 10. The MIU of the exemphiry embodiment includes six CDNfA modems, but the 
invention is not limited to this number of modems. The MIU includes: a System PCM 
Highway 1201 connected to each of the CDMA Modems 1210, 1211, 1212, 1215 through 
a PCM Interface 1220; a Control Channel Bus 1221 connected to MIU controller 1230 
and each of the CDMA Modems 1210, 1211, 1212, 1213; an MIU clock signal generator 
(CLK) 1231; and a modem ouQ)ut combiner 1232. The MIU provides the RCS with the 
following functions: the MIU controller receives CDMA Channel Assignment Instructions 
from die WAC and assigns a first modem to a user information signal which is applied to 
tiie line interface of tiie MUX and a second modem to receive die CDMA channel from 
tiie SU; die MIU also combmes tiie CDMA Transmit Modem Data for each of tfie MIU 
CDMA modems; multiplexes I and Q transmit message data from tiie CDMA modems for 
transmission to tiie VDC; receives Analog I and Q receive message data from tiie VDC; 
distributes tiie I and Q data to tiie CDMA modems; transmits and receives digital AGC 
Data; distributes tiie AGC data to tiie CDMA modems; and sends MIU Board Stams and 
Maintenance Information to the WAC 920. 

The MIU controller 1230 of tiie exemplary embodiment of tiie present 
invention contains one communication microprocessor 1240, such as tiie MC68360 
"QUICC" Processor, and includes a memory 1242 having a Flash Prom memory 1243 
and a SRAM memory 1244. Flash Prom 1243 is provided to contain tiie program code for 
tiie Microprocessors 1240, and tiie memory 1243 is downloadable and reprogrammable to 
support new program versions. SRAM 1244 is provided to contain tiie temporary data 
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space needed by the MC68360 Micrt^rocessor 1240 when the MIU controller 1230 reads 
or writes, data to memoiy 

The MIU CLK circuit 1231 provides a timing signal to the MIU controller 
1230, and also provides a timing signal to the CDMA modems. The MIU CliC circuit 
1231 receives and is synchronized to the system clock signal wo(t). The controller clock 
signal generator 1213 also receives and synchronizes to the ^reading co<te clock signal 
pn(t) which is distributed to the CDMA modems 1210, 1211, 1212, 1215 from the MUX. 

The RCS of the present embodiment includes a System Modem 1210 
contained on one MIU. The System Modem 1210 includes a Broadcast ^reader (not 
shown) and a Pilot Generator (not shown). The Broadcast Modem provides the broadcast 
mformation used by the exemplary system, and the broadcast message data is transferred 
from the MIU controller 1230 to the System Modem 1210. The System Modem also 
includes four additional modems (not shown) which are used to transmit the signals CTl 
through CT4 and AXl through AX4. The System Modem 1210 provides unweighted I 
and Q Broadcast message data signals which are applied to the VDC, The VDC adds the 
Broadcast message data signal to the MIU CDMA Modem Transmit Data of all CDMA 
modems 1210, 1211, 1212, 1215, and the Global Pilot signal. 

The Pilot Generator (PG) 1250 provides the Global PUot signal which is 
used by the present invention, and the Global Pilot signal is provided to die CDMA 
modems 1210, 1211, 1212, 1215 by the MIU controller 1230. Other embodiments of the 
present invention, however, do not require the MIU controller to generate the Global 
Pilot signal, but include a Global Pilot signal generated by any fonn of CDMA Code 
Sequence generator. In the described onbodiment of the invention, the unweighted I and 
Q Global Pilot signal is also sent to the VDC where it is assigned a weight, and added to 
the MIU CDMA Modem transmit data and Broadcast message data signal. 

System timing in die exemplary RCS is derived firom the El interface. 
There are four MUXs in an RCS, three of which (905, 906 and 907) are shown in Figure 
9. Two MUXs are located on each chassis. One of the two MUXs on each chassis is 
designated as the master, and one of the masters is designated as the qrstan master. The 
MUX which is the system master derives a 2.048 Mhz PCM clock signal from the El 
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interface using a phase locked lcx)p (not riiown). In turn, the system master MUX divides 
the 2.048 Mhz PCM clock signal in fiequency by 16 to derive a 128 KHz reference clock 
signal. Hie 128 KHz reference clock signal is distributed from the MUX that is the 
system master to all the other MUXs. In turn, each MUX multiplies the 128 KHz 
reference clock signal in firequency to syntheaze the system clock signal which has a 
ftequency that is twice the frequency of the PN-clock signal. Hie MUX also divides the 
128 KHz clock signal m frequency by 16 to generate the 8 KHz frame synch signal which 
is distributed to the MIUs. The system clock signal for the exemplary embodiment has a 
frequency of 1 1.648 Mhz for a 7 MHz bandwidth CDMA channel. Each MUX also 
divides the system clock signal in frequency by 2 to obtain the PN-clock agnal and 
fiirther divides the PN-clock signal in frequency by 29 877 120 (the PN sequence length) 
to generate the PN-synch signal which indicates the qpoch boundaries. The PN-synch 
signal from the system master MUX is also distributed to all MUXs to maintaui phase 
alignment of the internally generated clodc signals for each MUX. The PN-synch signal 
and die frame synch signal are aligned. The two MUXs that are designated as the master 
MUXs for each chasis then distribute both the system clodc signal and the PN-clock 
signal to the MIUs and the VDC. 

The PCM Highway Interface 1220 connects the System PCM Highway 91 1 
to each CDMA Modem 1210, 1211, 1212, 1215. The WAC controller transmits Modem 
Control information, including traffic message control signals for each re^)ectiive user 
information signal, to the MIU controller 1230 through the HSB 970. Each CDMA 
Modem 1210, 1211, 1212, 1215 receives a traffic message control signal, which includes 
signaling information, from the MIU. Traffic message control signals also include call 
control (CC) information and spreading code and despreadmg code sequence information. 

The MIU also mcludes the Transmit Data Combiner 1232 which adds 
weighted CDMA modem transmit data including In-phase (I) and (Juadraturc ((J) modem 
transmit data from the CDMA modems 1210, 1211, 1212, 1215 on the MIU. The I 
modem transmit data is added separately from the Q modem transmit data. The combined 
I and Q modem transmit data output signal of the Transmit Data Combiner 1232 is 
applied to the I and Q multiplexer 1233 tiiat creates a single CDMA transmit message 
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channel composed of the I and Q modem transmit data multiplexed into a digital data 
stream. 

The Receiver Data Input Circuit (RDI) 1234 receives the Analog 
Differential I and Q Data from the Video Distributi<m Circuit (VDC) 940 shown m Figure 

5 9 and distributes Analog Differential I and Q Data to each of the CDMA Modems 1210, 
1211, 1212, 1215 of the MIU. The Automatic Gam Control Distribution Circuit (AGC) 
1235 receives the AGC Data signal from the VDC and distributes the AGC Data to each 
of the CDMA Modems of the MIU. The TRL circuit 1233 receives the Traffic lights 
information and similarly distributes the Traffic light data to each of the Modems 1210, 

10 1211. 1212, 1215. 

The CDMA Modem 

The CDMA modem provides for graeration of CDMA spreading code 
sequences, synchronization between transmitter and receiver. It alsio provides four full 
duplex channels (TRO, TRl, TR2, TR3) programmable to 64, 32, 16, and 8 ksym/sec. 

15 each, spreading and transmission at a specific power level. The CDMA modem measures 
the received signal strength to allow Automatic Power Control, it generates and transmits 
pilot signals, encodes and decodes using the signal for forward error correction (FEC). 
The moden in a subscriber unit (SU) also performs transmitter spreading-code pulse 
shaping using an FIR filter. The CDMA modem is also used by the SU and, in the 

20 following discussion, those features which are used only by the SU are distincdy pointed 
out. The operating frequencies of the CDMA modem are given in Table 7. 



Table 7 Operating Frequencies 



Bandwidth 
(MHz) 


Chip Rate 
(MHz) 


Symbol Rate 
(KHz) 


Gain 

(Chips/Symbol) 


7 


5.824 


64 


91 


10 


8.320 


64 


130 


10.5 


8.512 


64 


133 


14 


11.648 


64 


182 


15 


12.480 


64 


195 
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Each CDMA modem 1210, 1211, 1212,'>i215 of Figure 10, andas sh6wn 
in Figure 11, is composed of a transmit section 1301 and a receive section 1302. Also 
included in the CDMA modem is a control center 1303 which receives control messages 
CNTRL from the external system. These messages are used, for example, to assign 

5 particular spreading codes, to activate the ^reading or deq)reading, or to assign 

transmission rates. In addition, the CDMA modem has a code generator means 1304 
used to generate the various spreading and de^reading codes used by the CDMA modem. 
The transmit section 1301 transmits the input information and control signals mi(t), 
1=1,2... I as spread-spectrum processed user information signals sqi(t), j=l,2,. J. The 

10 transmit section 1301 receives the global pilot code from the code generator 1304 which 
is controlled by the control means 1303. The spread ^>ectrum processed user information 
signals are ultimately added with other similarly processed signals and transmitted as 
CDMA channels over the CDMA RF forward message link, for example to the SUs. The 
receive section 1302 receives CDMA channels as r(t) and despreads and recovers the user 

15 information and control signals rck(t), k=l,2,..K transmitted over the CDMA RF reverse 
message link, for example to the RCS from the SUs. 

CDMA Modem Transmitter Section 

Referring to Figure 12, the code generator means 1304 includes Transmit 
Timing Control Logic 1401 and spreading code PN-Graerator 1402, and the Transmit 

20 Section 1301 includes MODEM Input Signal Receiver (MISR) 1410, Convolution 
Encoders 1411, 1412, 1413, 1414, Spreaders 1420, 1421, 1422, 1423, 1424, and 
Combiner 1430. The Transmit Section 1301 receives the message data diannels 
MESSAGE, convoludonally encodes each message data channel in the req)ective 
convolutional encoder 1411, 1412, 1413, 1414, modulates the data with random 

25 spreading code sequence in the respective spreader 1420, 1421, 1422, 1423, 1424, and 
combines modulated data from all channels, including the pilot code received in the 
described embodiment from the code generator, in the combiner 1430 to generate I and Q 
components for RF transmission. Hie Transmitter Section 1301 of the present 
embodiment supports four (TRO, TRl, TR2, TR3) 64, 32, 16, 8 Kbps programmable 

30 channels. The message channel data is a time multiplexed signal received from the PCM 
highway 1201 through PCM interface 1220 and input to the MISR 1410. 
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Figure 13 illustrates the block diagram of the MISR 1410. For the 
exemplary embodiment of the present invention, a counter is set by the 8 KHz frame 
synchronization signal MPCMSYNC and is incremented by 2.048 MHz MPCMCLK 
from the timing circuit 1401. The counter output is compared by comparator 1502 
against TRCFG values corresponding to slot time location for TRO, TRl, TR2, TR3 
message channel data; and the TRCFG values are received from the MIU Controller 1230 
in MCTRL. The comparator sends a count signal to the registers 1505, 1506, 1507, 1508 
which clocks message channel data into buffers 1510, 1511, 1512, 1513 using the 
TXPCNCLK timing signal derived from the system clock. The message data is provided 
from the signal MSGDAT from die PCM highway signal MESSAGE when enable signals 
TROEN, TRIEN, TR2EN and TR3EN from Timing Control Logic 1401 are active. In 
further embodiments, MESSAGE may also include signals that enable registers depending 
upon an encryption rate or data rate. If the counter ou^ut is equal to one of the channel 
location addresses, die specified transmit message data in registers 1510, 1511, 1512, 
1513 are input to the convolutional encoders 1411, 1412, 1413, 1414 shown m Figure 12. 

The convolutional encoder enables the use of Forward error correction 
(FEC) techniques, which are well known in the art FEC techniques depend on 
introducing redundancy in generation of data in encoded form. Encoded data is 
transmitted and the redundancy in the data enables the receiver decoder device to detect 
and correct errors. One exemplary system which uses a modem according to the present 
invention employs convolutional encoding. Additional data bits are added to the data in 
the encoding process and are the codmg overhead. The coding overhead is expressed as 
the ratio of data bits transmitted to the tool bits (code data + redundant data) transmitted 
and is called the rate "R" of the code 

Convolution codes are codes where each code bit is generated by the 
convolution of each new uncoded bit widi a number of previous coded bits. The total 
number of bits used in die encoding process is referred to as die constraint length, ^K", 
of the code. In convolutional coding, data is clocked into a shift register of K bits lengtii 
so that an incoming bit is clocked into the register, and it and die existing K-1 bits are 
convolutionally encoded to create a new symbol. The convolution process consists of 
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creating a symbol consisting of a module-2 sum of a certain pattern of available bits, 
always including the first bit and the last bit in at least one of the symbols. 

Figure 14 shows the block diagjam of K=7, R= 1/2 convolution encoder 
suitable for use as the encoder 1411 shown in Figure 12. This circuit encodes the TRO 
Channel as used in one embodiment of the present invention. Seven-bit Register 1601 
with stages Ql through Q7 uses the signal TXPNCLK to clock in TRO data when the 
TROEN signal is asserted. The output value of stages Ql, Q2, Q3, Q4, Q6, and Q7 are 
each combined using EXCLUSIVE-OR Logic 1602, 1603 to produce respective I and Q 
channel FEC data for the TRO channel FECTRODI and FECTRODQ. 

Two output symbol streams FECTRODI and FECTRODQ arc generated. 
The FECTRODI symbol stream is generated by EXCLUSIVE OR Logic 1602 of shift 
register outputs corresponding to bits 6, S, 4,3, and 0, (Octal 171) and is designed as In 
phase component of the transmit message channel data. The symbol stream 
FECTRODQ is likewise generated by EXCLUSIVE-OR logic 1603 of shift register 
ou^uts from bits 6, 4 3, 1 and 0, (Octal 133) and is designated as (^adrature component 
"Q" of the transmit message channel data. Two symbols are transmitted to represent a 
single encoded bit creating the redundancy necessary to enable error correction to take 
place on the receiving end. 

Referring to Figure 14, the shift enable clock signal for the transmit 
message channel data is generated by the Control Timing Logic 1401. The 
convolutionally encoded transmit message channel ou^ut data for each channel is applied 
to die respective spreader 1420, 1421, 1422, 1423, 1424 which multiplies the transmit 
message channel data by its preassigned spreading-code sequence from code generator 
1402. This spreading-code sequence is generated by control 1303 as previously 
described, and is called a random pseudonoise signature sequence (PN-code). 

The ou^ut signal of each spreader 1420, 1421, 1422, 1423, 1424 is a 
spread transmit data channel. The operation of the spreader is as follows: the ^reading of 
channel output (I + jQ) multiplied by a random sequence (PNI + jPN(2) yields the In- 
phase component I of the result being composed of (I xor PNI) and (-Q xor PNQ). 
Quadrature component Q of the result is (Q xor PNI) and (I xor PNQ). Since there is no 
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channel data input to the pilot channel logic (I~l, Q values are prohibited), the ^read 
output signal for pilot channels yields the respective sequences PNI for I component and 
PNQ for Q component. 

The combiner 1430 receives the I and Q spread transmit data channels and 
combines the channels into an I modem transmit data (TXIDAT) and Q modem transmit 
data (TXQDAT) signals. The I-spread transmit data and the Q spread transmit data aie 
added separately. 

For an SU, the CDMA modem Transmit Section 1301 includes the FIR 
filters to receive the I and Q channels firom the combiner to provide pulse shs^ing, close- 
in spectral control and x / sin (x) correction on the transmitted signal. Separate but 
identical FIR filters (not shown) receive the I and Q spread transmit data streams at the 
chipping rate, and the output signal of each of the filters is at twice the chipping rate. 
The FIR filters are 28 tap even symmetrical filters, which upsample (interpolate) by 2. 
The upsampling occurs before the filtering, so that 28 taps refers to 28 taps at twice the 
chipping rate, and the upsampling is accomplished by setting every other sample a zero. 
Exemplaiy coefficients are shown in Table 8. 

Table 8 - Coefficient Values 

Coeff.No.: 0 1 2 3 4 5 6 7 8 9 10 11 12 13 
Value: 3 -11 -34 -22 19 17 32 19 52 24 94 -31 277 468 

Coeff.No. 14 15 16 17 18 19 20 21 22 24 25 26 27 
Value 277 -31 -94 24 52-19 -32 17 19 -22 -34 -11 3 

CDMA Modem Receiver Section 

Referring to Figures 9 and 10, the RF receiver 950 of die present 
embodiment accepts analog input I and Q CDMA channels, which are transmitted to the 
CDMA modems 1210, 1211, 1212, 1215 tiirough tiie MIUs 931, 932, 933 ftom the VDC 
940. These I and Q CMDA channel signals are sampled by the CDMA modem receive 
section 1302 (shown in Figure 1 1) and converted to I and Q digital receive message signal 
using an Analog to Digital (A/D) converter 1730 of Figure 15. The sampling rate of die 
A/D converter of the exemplary embodiment of the present invention is equivalent to the 
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despreading code rate. The I and Q digital receive message signals are then despread with 
correlators using six different complex despreading code sequences corresponding to the 
spreading code sequences of the four channels (TRO, TRl, TR2, TR3), APC information 
and the pilot code. 

Time synchronization of the receiver to the received signal is sq)arated into 
two phases; there is an initial acquisition phase and then a tracking phase after the signal 
timing has been acquired. The mitial acquisition is done by sliding the locally generated 
pilot code sequence relative to the received signal and comparing the output signal of the 
pilot despreader to a threshold. The metiiod used is called sequential search. Two 
thresholds (match and dismiss) are calculated from the auxiliary despreader. Once the 
signal is acquired, die search process is stopped and tracking begins. The tracking 
maintains the code generator 1304 (shown in Figures 11 and 15) used by the receiver in 
synchronization with die incoming signal. The tracking loop used is the Delay-Locked 
Loop (DLL) and is implemented in die acquisition & track 1701 and the IPM 1702 blocks 
of Figure 15. 

In Figure 11, die modem controller 1303 implements the Phase Lock Loop 
(PLL) as a software algorithm in SW PLL logic 1724 of Figure 15 diat calculates the 
phase and frequency shift in the received signal relative to die transmitted signal. The 
calculated phase shifts are used to derotate die phase shifts in rotate and combme blocks 
1718, 1719, 1720, 1721 of the multipath data signals for combining to produce output 
signals corresponding to receive channels TRO', TRl', TR2% TR3\ The data is dien 
Viterbi decoded in Viterbi Decoders 1713. 1714, 1715, 1716 to remove die convolutional 
encoding in each of the received message channels. 

Figure 15 indicates that the Code Generator 1304 provides the code 
sequences Pn((t), 1=1,2, ..I used by die receive channel despreaders 1703, 1704, 1705, 
1706, 1707, 1708, 1709. The code sequences generated are timed in re^nse to die 
SYNK signal of die system clock signal and are determined by the CCNTRL signal from 
the modem controller 1303 shown in Figure 11. Referring to Figure 15, the CDMA 
modem receiver section 1302 includes Adaptive Matched Filter (AMP) 1710, Channel 
despreaders 1703, 1704, 1705, 1706, 1707, 1708, 1709, Pilot AVC 1711, Auxiliary 
AVC 1712, Viterbi decoders 1713. 1714, 1715. 1716. Modem output interface (MOI) 
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1717, Rotate and Combine logic 1718, 1719, 1720, 1721, AMF Weight Generator 1722, 
and Quantile Estimation logic 1723. 

In another embodiment of the invention, the CDMA modem receiver may 
also include a Bit error Integrator to measure the BER of the channel and idle code 
insertion logic between the Viterbi decoders 1713, 1714, 1715, 1716 and the MOI 1717 
to insert idle codes in the event of loss of the message data. 

The Adaptive Matched Filter (AMF) 1710 resolves muldpath interference 
introduced by the air channel The exemplary AMF 1717 uses an stage complex FIR filter 
as shown in Figure 16. The received I and Q digital message signals are received at the 
register 1820 from the A/D converter 1730 of Figure 15 and are multiplied in multipliers 
1801, 1802, 1803, 1810, 1811 by I and Q channel weights Wl to Wll received from 
AMF weight generator 1722 of Figure 15. In the exemplary embodunent, the A/D 
converter 1730 provides the I and Q digital receive message signal data as 2*s 
complement 6 bits I and 6 bits Q which are clocked through an 11 stage shift register 
1820 responsive to the receive spreading code clock signal RXPNCLK, The signal 
RXPNCLK is generated by the timing section 1401 of code generation logic 1304. Each 
stage of the shift register is tapped and complex muldplied in the multipliers 1801, 1802, 
1803, 1810, 1811 by individual (6-bit I and 6-bit Q) weights to provide 11 t^weighted 
products which are added in adder 1830, and limited to 7-bit I and 7-bit Q values. 

The CDMA modem receive section 1302 (shown in Figure 11) provides 
independent channel despreaders 1703. 1704, 1705, 1706, 1707, 1708, 1709 (shown in 
Figure 15) for despreading the message channels. The described embodiment despreads 7 
message channels, each despreader accepting a 1-bit I b 1-bit Q spreading code signal to 
perform a complex correlation of this code against a 8-bit I by 8-bit Q data input. The 7 
despreaders correspond to tiie 7 channels: Traffic Channel 0 (TRO'), TRr, TR2', TR3\ 
AUX (a spare channel). Automatic Power Control (APC) and pilot (PLT). 

The Pilot AVC 1711 shown in Figure 17 receives die I and Q Pilot 
Spreading code sequence values PCI and PCQ into shift register 1920 responsive to die 
timing signal RXPNCLK, and includes 11 individual despreaders 1901 througlh 1911 each 
correlating the I and Q digital receive message signal data widi a one chip delayed 
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versions of the same pilot code sequence. Signals OEl, 0E2, ..OEll are used by the 
modem control 1303 to enable the despreading operation. The ou^ut signals of the 
despreaders are combined in combiner 1920 forming correlation signal DSPRDAT of the 
Pilot AVC 1711, which is received by the ACQ & Track logic 1701 (shown in Figure 
15), and ultimately by modem controller 1303 (shown in Figure 11). The ACQ & Track 
logic 1701 uses the correlation signal value to determine if the local receiver is 
synchronized with its remote transmitter. 

The Auxiliary AVC 1712 also receives the I and Q digital receive message 
signal data and, in the described embodiment, includes four separate despreaders 2001, 
2002, 2003, 2004 as shown in Figure 18. Each despreader receives and correlates the I 
and Q digital receive message data with delayed versions of the same de^reading-code 
sequence PARI and PARQ which are provided by code generator 1304 input to and 
contained in shift register 2020. The ou^ut signals of the despreaders 2001, 2002, 2003, 
2004 are combined in combiner 2030 which provides noise correlation signal 
ARDSPRDAT. The auxiliary AVC despreading code sequence does not corre^nd to 
any transmit spreading-code sequence of the system. Signals OEl, 0E2, ..0E4 are used 
by the modem control 1303 to enable the despreading operation. The Auxiliary AVC 
1712 provides a noise correlation signal ARDSPRDAT from which quandle estimates are 
calculated by the Quantile estimator 1733, and provides a noise level measurement to the 
ACQ & Track logic 1701 (shown in Figure 15) and modem controller 1303 (shown in 
Figure 11). 

Each despread channel output signal corresponding to the received message 
channels TRO*, TRl', TR2\ and TR3' is input to a corresponding Viteibi decoder 1713, 
1714, 1715, 1716 shown in Figure 15 which performs forward error correction on 
convolutionally encoded data. The Viterbi decoders of the exemplary embodiment have a 
constraint length of K=7 and a rate of R= 1/2. The decoded despread message channel 
signals are transferred from the CDMA modem to the PCM Highway 1201 tiirough the 
MOI 1717. The operation of the MOI is very similar to the operation of the MISR of the 
transmit section 1301 (shown in Figure 11), except in reverse. 
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The CDMA modem receiver section 1302 implements several different 
algorithms during different phases of the acquisition, tracking and despreading of the 
receive CDMA message signal. 

When the received signal is momentarily lost (or severely degraded) the 
idle code insertion algorithm inserts idle codes in place of the lost or degraded receive 
message data to prevent the user from hearing loud noise bursts on a voice call. The idle 
codes are sent to the MOI 1717 (shown m Figure IS) in place of the decoded message 
channel output signal from the Viterbi decoders 1713, 1714. 1715, 1716. The idle code 
used for each traffic channel is programmed by the Modem Controller 1303 by writing 
the appropriate pattern IDLE to the MOI, which in the present embodiment is a 8 bit 
word for a 64 kbps stream, 4 bit word for a 32 lips stream. 

Modem Algorithms for Acquisition and Tracking of Received PUot Signal 

The acquisition and tracking algorithms are used by the receiver to 
determine the approximate code phase of a received signal, synchronize the local modem 
receiver despreaders to the incoming pilot signal, and track the phase of the locally 
generated pilot code sequence with the received pilot code sequence. Referring to Figures 
11 and 15, the algorithms are performed by the Modem controller 1303, which provides 
clock adjust signals to code generator 1304. These adjust signals cause the code generator 
for the despreaders to adjust locally generated code sequences in response to measured 
ou^ut values of the Pilot Rake 1711 and (Juantile values from quantile estimators 1723B, 
(Juantile values are noise statistics measured from the In-phase and (Quadrature channels 
from the output values of the AUX Vector Correlator 1712 (shown in Figure 15). 
Synchronization of the receiver to the received signal is separated into two phases; an 
initial acquisition phase and a tracking phase. The mitial acquisition phase is 
accomplished by clocking the locally generated pilot spreading code sequence at a higher 
or lower rate than the received signal's spreading code rate, sliding the locally generated 
pilot spreading code sequence and performing sequential pr<*ability ratio test (SPRT) on 
the output of the Pilot Vector correlator 1711. The tracking phase mamtains the locally 
generated spreading code pilot sequence in synchronizadon with the incoming pilot signal. 
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The SU cold acquisition algorithm is used by the SU CDMA modem when 
it is first powered-up, and therefore has no knowledge of the correct pilot spreading code 
phase, or when an SU attempts to reacquire synchronization with the mooming pilot 
signal but has taken an excessive amount of time. The cold acquisition algorithm is 
divided into two sub-phases. The first subphase consists of a search over the lengfli 
233415 code used by the FBCCH. Once tiiis sub-code phase is acquired, the pilot's 
233415 X 128 lengtii code is known to within an ambiguity of 128 possible phases. The 
second subphase is a search of these remaining 128 possible phases. In order not to lose 
synch with the FBCCH. tiie second phase of tiie search it is desirable to switch back and 
forth between tracking tiie FBCCH code and attempting acquisition of tiie pilot code. 

The RCS acquisition of short access pilot (SAXPT) algoritimi is used by an 
RCS CDMA modem to acquire tfie SAXPT pilot signal of an SU. The algoritiun is a fest 
search algoritiim because the SAXPT is a short code sequence of lengtii N, where N = 
chips/symbol, and ranges from 45 to 195, depending on the system's bandwidtii. The 
search cycles tiirough all possible phases until acquisition is complete. 

The RCS acquisition of the long access pilot (LAXPT) algoritimi begins 
immediately after acquisition of SAXPT. TTie SU's code phase is known witiiin a 

« 

multiple of a symbol duration, so in die exemplary embodiment of tixe invention, tiiere 
may be 7 to 66 phases to search widiin tiie round trip delay from the RCS. This bound is 
a result of the SU pilot signal being synchronized to tfie RCS Global pilot signal. 

The re-acquisition algoritiim beg'ms when loss of code lock (LOL) occurs. 
A Z-search algoritiim is used to speed tiie process on the assumption tiiat tiie code phase 
has not drifted far from where it was tiie last time the system was locked. The RCS uses 
a maximum widdi of tiie Z-search windows bounded by tiie maximum round trip 
propagation delay. 

The Pre-Track algorithm immediately follows the acquisition or re- 
acquisition algoridims and immediately precedes tiie tracking algoritiim. Pre-track is a 
fixed duration period during which tiie receive data provided by tiie modem is not 
considered valid. The Pre-Track period allows odier modem algorithms, such as tfiose 
used by tiie ISW PLL 1724, ACQ & Tracking, AMF Weight GEN 1722, to prepare and 
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adapt to the current channel. The Pre-track algorithm is two parts. The first part is the 
delay while die code tracking loop pulls in. The second part is the delay while the AMF 
t^ weight calculations are performed by the AMF Weight Gen 1722 to produce setded 
weighting coefficients. Also in the second part of die Pre-Track period, the carrier 
5 tracking loop is allowed to pull in by the SW PLL 1724, and the scalar quantile estimates 
are performed in the Quantile estimator 1723A. 

The Tracking process is entered after die Pre-Track period ends. This 
process is actually a repetitive cycle and is the only process phase during whidi receive 
data provided by the modem may be considered valid. The following operations are 
10 performed during fliis phase: AMF T^ Weight Update, Carrier Tracking, Code 

Tracking, Vector Quantile Update, Scalar Quantile Update, Code Lock Check, Derotation 
and Symbol Summing, and Power Control (forward and reverse). 

If loss of lock (LOL) is detected, die modem receiver terminates the Track 
algorithm and automatically enters the reaquisition algorithm. In the SU, a LOL causes 

15 the transmitter to be shut down. In the RCS, LOL causes forward power control to be 
disabled with the transmit power held constant at the level immediately prior to loss of 
lock. It also causes the return power control information being transmitted to assume a 
010101... pattern, causing the SU to hold its transmit power constant. This can be 
performed using tfie signal lock check function which generates the reset signal to the 

20 acquisition and tracking circuit 170L 

Two sets of quantile statistics are maintained, one by Quantile estimator 
1723B and the odier by the scalar Quantile Estimator 1723A. Both arc used by the 
modem controller 1303. The first set is the "vector" quantile information, so named 
because it is calculated from the vector of four complex values generated by the AUX 

25 AVC receiver 1712. TTie second set is the scalar quantile information, which is calculated 
from the single complex value AUX signal diat is ouq)ut from die AUX Despreader 1707. 
The two sets of information represent different sets of noise statistics used to maintain a 
pre-determined Probability of False Alarm (Pin). The vector quantile data is used by the 
acquisition and reaquisition algorithms implemented by die modem controller 1303 to 

30 determine die presence of a received signal in noise, and die scalar quantile information is 
used by the code lock check algorithm. 
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For both the vector and scalar cases, quantile information consists of 
calculated values of lambdaO through lanibda2, which are boundary values used to 
estimate the probability distribution function (p.d.f.) of the despiead received signal and 
determine whether the modem is locked to the PN code. The Aux^Power value used in 
the following C-subroutine is the magnitude squared of the AUX signal output of the 
scalar correlator array for the scalar quantiles, and the sum of the magnitudes squared for 
the vector case. In both cases the quantiles are then calculated usmg the following C- 
subroutine: 

for(n = 0; n < 3; n++) { 

lambda [n] -h= (lambda [n] < Aux^Power) ? CG[n] : GM[n]; 
} 

where CG[n] are positive constants and GM[n] are negative constants (different values are 
used for scalar and vector quantiles). 

During the acquisition phase, the search of flie incoming pilot signal witii 
the locally generated pilot code sequence employs a series of sequential tests to determine 
if the locally generated pilot code has the correct code phase relative to the received 
signal. The search algorithms use tiie Sequential Probability Ratio Test (SPRT) to 
determine whether tiie received and locally generated code sequences are in phase. The 
speed of acquisition is increased by flie parallelism resulting from having a multi-fingered 
receiver. For example, in tiie described embodiment of the invention tiie main Pilot Rake 
171 1 has a total of 1 1 fingers representing a total phase period of 11 chip periods. For 
acquisition 8 separate sequential probability ratio tests (SPRTs) are implemented, witii 
each SPRT observing a 4 chip window. Each window is offset from the previous window 
by one chip period, and in a search sequence any given code phase is covered by 4 
windows. If all 8 of the SPRT tests are rejected, then the set of wmdows is moved by 8 
chips. If any of tiie SPRT*s is accepted, tiien the code phase of tiie locally generated pilot 
code sequence is adjusted to attempt to center tiie accepted SPRT's phase witiiin tiie Pilot 
AVC. It is likely tiiat more tiian one SPRT reaches tiie acceptance tiireshold at tiie same 
time. A table lookup is used cover all 256 possible combinations of accept/reject and tiie 
modem controller uses tiie information to estimate tiie correct center code phase widiin 
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the Pilot Rake 1711. Each SPRT is implemented as follows (all operations occur at 64k 
symbol rate): Denote the fingers' output level values as I_Finger[n] and Q_Fmger[n], 
where n=0..10 (inclusive, 0 is earliest (most advanced) finger), then the power of each 
window is: 

Power Window[i] = Z (I_Rngei^[n] + CLFinger^[n] 

n 

To implement the SPRT's the modem controller then performs for each of the windows 
the following calculations which are e}q)ressed as a pseudo-code subroutine: 

/* find bin for Power */ 

tmp = SIGMA[0]; 

for(k = 0;k< 3;k++){ 

if (Power > lambda [k]) tmp ^ SIGMA[k+l]; 

} 

test^statistic += tmp; /* update statistic */ 

if(test_statistic > ACCEPTANCE_THRESHOLD)you've got ACQ; 

elseif (test_statistic < DISMISSAL^THRESHOLD) { 

forget this code phase; 
} else keep trying - get more statistics; 

where lambda[k] are as defined in the above section on quantile estimation, and 
SIGMA[k], ACCEPTANCE_THRESHOLD and DISMISSAL^THRESHOLD are 
predetermined constants. Note diat SIGMA[k] is negative for values for low values of k, 
and positive for right values of k, such tiiat the acceptance and dismissal thresholds can be 
constants rather than a function of how many symbols worth of data have been 
accumulated in the statistic. 

The modem controller determines which bin, delimited by the values of 
lambda[k], the Power level falls into which allows the modem controller to develop an 
approximate statistic. 
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For the present algorithm, the control voltage is formed as e = y^y, 
where y is a vector formed from the complex valued output values of the Pilot Vector 
correlator 171 1, and B is a matrix consisting of the constant values pie-detennined to 
maximixe the operating characteristics while minimizing the noise as described above 
with reference to the Quadratic Detector. 

To understand the operation of the Quadratic Detector, it is useful to 
consider the following. A spread spectrum (CDMA) signal, 5(t) is passed through a 
multipath channel with an impulse response hc(t). The baseband spread signal is 
described by equation (27). 

^(0 = ZM'-'^c) (27) 

where Ci is a complex spreading code symbol, p(t) is a predefined chip pulse and Tc is the 
chip time spacing, where Tc = 1/Rc and Rc is the chip rate. 

The received baseband signal is represented by equation (28) 

'•(O = Z - '^c - 0 + Mi) (28) 

where q(t) = p(t)*hc(t), t is an unknown delay and n(t) is additive noise. The received 
signal is processed by a filter, hR(t), so the waveform, x(t), to be processed is given by 
equation (29). 

^(0 = ZC./(^-'X- 0+^(0 (29) 

where f(t) = q(t)*hR(t) and 2(t) = n(t)*hR(t). 

In the exemplary receiver, samples of the receive signal are taken at the 
chip rate, that is to say. 1/Tc. These samples, x(mTc+x'), are processed by an array of 
correlators that compute, during the r* correlation period, the quantities given by equation 
(30) 

vr= Z^W + OC, (30) 
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These quantities are composed of a noise component W*^ and a 
deterministic component yk^*^ given by equation (31). 

>'r=£[vn = W7; + r'-r) (31) 

In the sequel, the time index r may be suppressed for ease of writing, although it is to be 
5 noted that the function f(t) changes slowly with time. 

The samples are processed to adjust the sampling phase, x\ in an optimum 
fashion for further processing by the receiver, such as matched filtering. This adjustment 
is described below. To simplify the representation of the process, it is helpful to describe 
it in terms of the function f(t+x), where the dme-shift, x, is to be adjusted. It is noted 
10 that the function f(t+x) is measured in the presence of noise. Thus, it may be 

problematical to adjust the phase x* based on measuremrats of the signal f(t+x). To 
account for the noise, the function v(t): v(t)=f(t)+m(t) is introduced, where the term 
m(t) represents a noise process. Tlie system processor may be derived based on 
considerations of the function v(t). 

15 The process is non-coherent and therefore is based on the envelope power 

function |v(t+x)|^. The functional e(x*) given in equation (32) is helpful for describing 
the process. 

e(r') = j^|v(/ + x'-tfdt - J^|v(/ + r'-r)p dt (32) 

The shift parameter is adjusted for e(x')=0, which occurs when the energy on the interval 
20 (-a>,x*-xl equals that on the interval [x*-x,oo). The error characteristic is monotonic and 
therefore has a single zero crossing point. This is the desirable quality of the functional. 
A disadvantage of the functional is that it is ill-defined because the integrals are 
unbounded when noise is present. Neverdieless, die functional e(x*) may be cast in the 
form given by equation (33). 

25 e(r*) = £ w(/)i v(/ + r'^-rfdi (33) 

where the characteristic function w(t) is equal to sgn(t), the signum function. 
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To optimize the characteristic function w(t), it is helpful to define a figure 
of merit, F, as set forth in equation (34), 

The numerator of F is the numerical slope of the mean error characteristic on the interval 
5 [-Ta,Ta] surrounding the tracked value, to\ The statistical mean is taken with respect to 
the noise as well as the random channel, hc(t). It is desirable to specify a statistical 
characteristic of the channel in order to perform this statistical average. For example, the 
channel may be modeled as a Wide Sense Stationary Uncorrelated Scattering (WSSUS) 
channel with impulse response hc(t) and a white noise process U(t) that has an intensity 
10 function g(t) as shown in equation (35). 

K(t)^4^Uit) (35) 

The variance of e(x) is computed as the mean square value of the 

fluctuation 

e'(r) = e(r)-<e(r)) (36) 
15 where < e(x) > is the average of e(T) with respect to the noise. 

Optimization of the figure of merit F widi respea to the function w(t) may 
be carried out using well-known Variational metiiods of optimiiation. 

Once tiie optimal w(t) is determined, tiie resulting processor may be 
approximated accurately by a quadratic sample processor which is derived as follows. 

20 By die sampling theorem, the signal v(t), bandlimited to a bandwidtii W 

may be expressed in terms of its samples as shown in equation (37). 

v(/) = 2 / W)^no[iWt - k)K] (37) 

substituting this expansion into equation (z+6) results in an infinite quadratic form in the 
samples v(k/W+T'-T). Making the assumption that the signal bandwidtii equals the chip 
25 rate allows the use of a sampling scheme tiiat is clocked by the chip clock signal to be 
used to obtain the samples. These samples, Vk are represented by equation (38). 
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V, = v(Jt7; + r' - r) (38) 

This assumption leads to a simplification of the implementation. It is valid if the aliasing 
error is small. 

In practice, the quadratic form that is derived is truncated. An example 
normalized B matrix is given below in Table 12. For this example, an exponential delay 
spread profile g(t)-exp(-t/t) is assumed with x equal to one chip. An qierture parameter 
Ta equal to one and one-half chips has also been assumed. The underlying diip pulse has 
a raised cosine spectrum with a 20% excess bandwidth. 



Table 12 - Example B matrix 
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0 
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-0.1 


0 


0 
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0 


0 


0 


0 


0 


-0.1 


0.22 


0.19 


-0.19 


0 


0 


0 


0 


0 


0 


0 


0 


0.19 


1 


0.45 


-0.2 


0 


0 


0 


0 


0 


0 


0 


-0.19 


0.45 


0.99 


0.23 


0 


0 


0 


0 


0 


0 


0 


0 


-0.2 


0.23 


0 


-0.18 


0.17 


0 


0 


0 


0 


0 


0 


0 


0 


-0.18 


-0.87 


-0.42 


0.18 


0 


0 


0 


0 


0 


0 


0 


0.17 


-0.42 


-0.92 


-0.16 


0 


0 


0 


0 


0 


0 


0 


0 


0.18 


-0.16 


-0.31 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


-0.13 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 


0 



Code tracking is implemented via a loop phase detector that is implemented 
as follows. The vector y is defined as a column vector which represents the 1 1 complex 
ou^ut level values of the Pilot AVC 1711, and B denotes an 11 x 11 symmetric real 
valued coefficient matrix with pre-determined values to optimize performance with the 
non-coherent Pilot AVC ouq>ut values y. As described above, the phase detector output 
is given by equation (39): 
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e = y^y (39) 

The following calculations are then performed to implement a proportional plus integral 
loop filter and the VCO: 

x[n] = x[n-l] +p8 
5 z[n] = z[n-l] + x[n] +ae 

for p and a which are constants chosen from modeling the system to optimize system 
performance for the particular transmission channel and application, and where x[n] is the 
loop filter's integrator output value and z[n] is the VCO oatput value. The code phase 
adjustments are made by the modem controller the following pseudo-code subroutine: 

10 if (z > zmx) { 

delay phase 1/16 chip; 

z -= zmax; 
} else if (z < -zmax) { 

advance phase 1/16 chip; 
15 z + — zmax; 

} 

A different delay phase could be used in die above pseudo-code subroutine oonsistant with 
the present invention. 

The AMF Tap-Weight Update Algorithm of the AMF Weight Gen 1722 
20 (shown in Figure 15) occurs periodically to de-rotate and scale the phase each finger value 
of the Pilot Rake 1711 by performing a complex multiplication of the Pilot AVC finger 
value with the complex conjugate of the current ou^ut value of the carrier tracking loop 
and applying the product to a low pass filter to produce AMF tap-weight values, which 
are periodically written into the AMF filters of die CDMA modem. 

25 The Code lock check algoritiim, shown in Figure 15) is implemented by 

the modem controller 1303 performing SPRT operations on the output signal of the scalar 
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correlator array. The SPRT technique is the same as that for the acquisition algorithms, 
except that the constants are changed to increase the probability of detection of lode. 

Carrier tracking is accomplished via a second order loop that operates on 
the pilot ouq)ut values of the scalar correlated array. The phase detector ou^ut is the 
hard limited version of die quadrature component of die product of the (complex valued) 
pilot output signal of the scalar correlated array and die VCO output agnal. The loop 
filter is a proportional plus integral design. The VCO is a pure summation, accumulated 
phase error f , which is converted to the complex phasor cos f + j sin f using a look-up 
table in memory. 

The previous description of acquisition and tracking algorithm focuses on a 
non-coherent mediod because the acquisition and tracking algoridim described uses non- 
coherent acquisition following by non-coherent tracking. This is done because, during 
acquisition, a coherent reference is not available until die AMF, Pilot AVC, Aux AVC, 
and DPLL are in an equilibrium state. It is, however, known in the art diat coherent 
tracking and combining is preferred because in non-coherent tracking and combining tiie 
output phase infonnation of each Pilot AVC finger is lost. ConsequenUy, anotiier 
embodiment of the invention employs a two step acquisition and tracking system, in 
which tiie previously described non-coherent acquisition and tracking algoritiun is 
implemented first, and tiien tiie system switches to a coherent traddng metiiod. The 
coherent combining and tracking metiiod is similar to diat described previously, txcept 
tiiat tiie error signal tracked is of tiie form: 

s = y^Ay (40) 

where y is defined as a column vector which represents tiie 11 complex ou^ut level 
values of tiie Pilot AVC 171 1, and A denotes an 1 1 x 11 symmetric real valued 
coefficient matrix witii pre-determined values to optimize performance witii the coherent 
Pilot AVC ouqiuts y. An exemplary A matrix is shown below. 
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10000000000 
01000000000 
00100000000 
00010000000 
00001000000 
A= 00000000000 (41) 

000000-1 0000 
000000 0-1 000 
00000000-1 00 
00000000 0-1 0 
000000000 0-1 

Although the invention has been described in teims of multiple exemplary 
embodiments, it is understood by those sidlled in the art that the invention may be 
practiced with modifications to the embodiments which are within the scope of the 
invention defined by the following claims. 
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The Invention Claimed Is: 

1 1. A Q)de Division Multiple Aa:ess (CDMA) modeni for tnmsmitdng 

2 receiving telecommunication signals including information signals and connection control 

3 signals, the modem comprising 

4 a modem transmitter having: 

5 a) code generation means comprising a generic pilot code means for 

6 providing an associated pilot code signal and a message means for 

7 generating a plurality of message code signals; 

s b) spreading means coupled to the message means for combining 

9 each of the information signals, with a respective one of the plurality of 

10 message code signals to generate a plurality of spread-spectrum processed 

11 message signals comprising a transmit Code Division Multiplex (CDM) 

12 signal, and the associated pilot signal wherein each of the plurality of 

13 message code signals of the plurality of modem processing means is 

14 synchronous with the global pilot code signal; and 

15 a modem receiver means having 

16 a) local code generation means comprising a local associated pilot 

17 code means for providing a local associated pilot code signal and a local 

18 message code means for generating a plurality of local message code 

19 signals, the local associated pilot code means being synchronous with the 

20 local message code means; 

21 b) an associated pilot code acquisition and tracking means 

22 comprising a plurality of associated pilot code-phase delayed correlation 

23 means for correlating respective phase-delayed versions of the local 

24 associated pilot code signal with a received CDM signal to produce a 

25 despread associated pilot signal, the code phase of the associated pilot code 

26 signal being changed responsive to an acquisition signal; and means for 

27 detecting the presence of the despread associated pilot signal to produce an 

28 acquisition signal, the acquisition signal indicating a degree of 
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29 synchronization between the local associated pilot code signal and the 

30 global pilot code signal; 

31 c) an associated pilot code tracking means including means for 

32 adjusting the local associated pilot code signal in phase responsive to the 

33 acquisition signal in a sense which tends to increase the level of the 

34 despread associated pilot signal; and 

35 . d) a plurality of message signal acquisition means for providing a 

36 plurality of despread receive message signals, each message signal 

37 acquisition means including a receive message signal correlator for 

38 correlating one of the local receive message code signals with the CDM 

39 signal to produce a respective despread receive message signal. 

1 2. The CDMA modem means of claim 1, wherein the modem transmitter means 

2 further comprises: 

3 spreading means coupled to the message means for combining each of the 

4 information signals and the call control signals, including user identification signals, with 

5 a respective one of the plurality of message code signals to generate a plurality of spread- 

6 spectrum processed message signals. 

1 3. The CDMA modem means of claim 1, wherein the modem receiver means 

2 further comprises: 

3 a) the pilot code acquisition and tracking means comprising 

4 A) associated pilot code generation means for providing the 

5 local associated pilot signal; 

6 B) a pilot vector correlator including a plurality of associated 

7 pilot code-phase delayed correlation means for correlating the local 

8 associated pilot signal with the receive CDM signal to produce a plurality 

9 of despread multipath pilot signals, and for providing a multipath weight 

10 signal corresponding to a respective multipath carrier of a respective one of 

11 the despread multipath pilot signals; 
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12 C) a pilot adaptive matched filter including a plurality of 

13 signal weighting means for scaling, in magnitude, and rotating the 

14 respective despread multipath pilot signals and each responsive to the 

15 respective multipath weighting signal, the plurality of signal weighting 

16 means providing a plurality of weighed despread multipath pilot signals, 

17 and a summing means for summing the plurality of weighted despread 

18 multipath pilot signals to form a despread associated pilot signal; 

19 D) means coupled to the pilot vector correlator for detecting 

20 the despread associated pilot signal and for producing an acquisition signal, 

21 the acquisition signal having a magnitude which is proportional to the 

22 despread associated pilot code signal in signal energy, the magnitude of the 

23 acquisition signal indicating a degree of synchronization between the 

24 associated pilot code signal and the local global pilot signal; and 

25 E) associated pilot code tracking means including means for 

26 adjusting the associated pilot code signal in code phase, responsive to the 

27 acquisition signal in a sense which tends increase in signal energy the 

28 despread associated pilot signal; 

29 b) a plurality of message signal acquisition means for providing a plurality of 

30 despread receive message signals, each including 

31 A) a plurality of receive message signal correlators for 

32 correlating one of the receive message code signals with the CDM signal to 

33 produce a plurality of despread multipath receive message signals 

34 respectively; 

33 B) a message adaptive matched filter including a plurality of 

36 signal weighting means for aligning the respective despread multipath 

37 receive message signals in carrier phase re^nsive to a req>ectively 

38 different one of the multipath weighting ugnals, the plurality of signal 

39 weighting means providing a plurality of weighted despread multipatii 

40 receive message signals, and a summing means for summing the plurality 
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41 of weighted despread multipath receive message signals to form a despiead 

42 receive message signal; 

43 c) the plurality of despread receive message signals include at least one despread 

44 information signal and a plurality of call control signals. 

1 4. The CDMA modem means of claim 3 wherein the plurality of call control 

2 signals include the user identification signal which identifies the user for the respective 

3 despread information signal and a message type signal which indicates a type and an 

4 information rate for the despread information signal. 

1 S. A method for tracking a centroid of a plurality of multipath spread-spectrum 

2 signals, said plurality of multipath spread-spectrum signals constituting a spread-spectrum 

3 channel signal including a transmitted code sequence, the method comprising the st^s of: 

4 digitally sampling the spread-spectrum channel signal responsive to a clock signal 

5 to produce a sequence of sample values including a set of even numbered sample values 

6 and a set odd-numbered sample values; wherein said the set of even-numbered sample 

7 values define a sequence of early spread-spectrum channel signal samples and said set of 

8 odd numbered sample values define a sequence of late ^read-spectrum diannel signal 

9 samples; 

10 generating a plurality of local code sequences, each of said plurality of local code 

11 sequences having a code phase and code symbol period, and each being a code phase- 

12 shifted version of the transmitted code sequence; 

13 combining each of said plurality of local code sequences with the sequence of 

14 early received spread-spectrum channel signal samples to produce a plurality of early 

15 despread multipath signals, and combining each of said plurality of local code sequences 

16 with the sequence of late received spread-^>ectrum channel signal samples to produce a 

17 plurality of late despread multipath signals; 

18 processing the plurality of early despread multipadi signals to produce an early 

19 tracking value, and processing the plurality of late de^iead multipadi signals to produce a 

20 late tracking value 
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21 determining a difference between the early tracking value and the late tracking 

22 value to produce an error signal value; and 

23 adjusting the code phase of each of said plurality of local code sequences 

24 responsive to the error signal value. 

1 6. The method of claim 5, wherein the steps of processing the plurality of early 

2 despread multipath signals and processing the plurality of late despread multipatb signals 

3 comprise the steps of: 

4 accumulating said plurality of early despread multipath signals to produce a 

5 respective plurality of early signal samples, and accumulating said plurality of late 

6 despread multipath signals to produce a respective plurality of late signal samples; and 

7 summing ones of the early signal samples to produce said early tracking value, and 

8 summing ones of the late signal samples to produce said late tracking value, 

1 7. The method of claim 6. wherein, prior to the step of summing, the method 

2 includes the step of weighting each of said early signal samples and each of said late 

3 signal samples with a respective predetermined weighting value. 

1 8. The method of claim 5, wherein the steps of adjusting the code phase of each 

2 of said plurality of local code sequences includes the step of increasing each code phase 

3 by a first predetermined number of code symbol periods responsive to the error signal 

4 value being negative, and decreasing each code phase by a second predetermmed number 

5 of code symbol periods responsive to the error signal value bemg positive. 

1 9, The method of claim 5, wherein the stq> of adjusting the code phase of each of 

2 said plurality of local code sequences includes the steps of increasing each code phase by 

3 a first predetermined number of code symbol periods re^nsive to die error signal value 

4 being positive, and decreasing each code phase by a second predetermined number of 

5 code symbol periods responsive to the error signal value being negative. 

1 10. Apparatus for tracking a centroid of a plurality of multipath spread-spectrum 

2 signals, said plurality of multipath spread-spectrum signals constituting a spread-spectrum 

3 channel signal including a transmitted code sequence, the ^paratus comprising: 
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4 an analog-to-digital converter, responsive to a clock signal and the spread- 

5 spectrum channel signal, to produce a sequence of sample values includmg a set of even 

6 numbered sample values and a set odd-numbered sample values; wherein said the set of 

7 even-numbered sample values defme a sequence of early spread-q)ectrum diannel signal 
s samples and said set of odd sample number values defme a sequence of late ^read- 

9 spectrum chaxmel signal samples; 

10 code sequence generating means for generating a plurality of local code sequences, 

11 each of said plurality of local code sequences having a code phase and code symbol 

12 period, and each being a code phase-shifted version of the transmitted code sequence; 

13 means for combining each of said plurality of local code sequences with the 

14 sequence of early received spread-spectrum channel signal samples to produce a plurality 

15 of early despread multipath signals, and for combining each of said plurality of local code 

16 sequences with the sequence of late received spread-q)ectrum channel signal samples to 

17 produce a plurality of late despread multipath signals; 

18 means for processing the plurality of early despread multipath signals to produce 

19 an early tracking value, and for processing the plurality of late despread multipath signals 

20 to produce a late tracking value 

21 a subtracter which determines the difference between tfie early tracking value and 

22 the late tracking value to produce an error signal value; and 

23 means, coupled to the code phase generating means, for adjustmg the code phase 

24 of each of said plurality of local code sequences responsive to the error signal value. 

1 1 L The apparatus of claim 10, wherein the means for processing the plurality of 

2 early despread multipath signals and for processing the plurality of late despread multipath 

3 signals comprise: 

4 a first plurality of accumulators which accumulate said plurality of early despread 

5 multipath signals to produce a respective plurality of early signal samples, and a second 

6 plurality of accumulators which accumulate said plurality of late despread muldpath 

7 signals to produce a respective plurality of late signal samples; and 
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8 a first summing network for summing ones of the early signal samples to produce 

9 said early tracking value, and a second summing network for summing ones of the late 

10 signal samples to produce said late tracking value. 

1 12. The apparatus of claim 1 1 , further including a plurality of signal scalers 

2 which multiply each of said early signal samples and each of said late signal samples by a 

3 respective predetermined weighting value and which apply the weighted odd and even 

4 signal samples to the respective first and second sunmiing networks. 

1 13. An adaptive matched filter (AMF) ^paratus for collecting signal power of a 

2 spread data channel in a spread-spectrum communication system from a q)read signal 

3 having a plurality of multipath signal components, eadi of said multipath signal 

4 components having a carrier phase, wherein said spread signal includes a spread pilot 

5 channel employing a first predetermined spreading code sequence and a spread data 

6 chaimel employing a second predetermined spreading code sequence, said spread pilot 

7 channel is unmodulated and said spread data channel is data*moduIated; the AMF 

8 apparatus comprising: 

9 pilot vector correlator means, coupled to receive the spread signal, for providing a 

10 plurality of multipatii signal weighting values determined from the spread pilot channel, 

11 each multipath signal weighting value corresponding to a respective multipath signal 

12 carrier of the respective received multipath signal component; 

13 local code sequence generator means for generating a plurality of local code 

14 sequences, each of the local code sequences being a code phase-shifted version of the 

15 predetermined spreading code sequence; 

16 data AMF means, coupled to receive the spread signal, for providing a data value 

17 determined from the spread data chaimel, the data AMF means comprising: 

18 a) a plurality of spreading code correlators, each spreading code 

19 correlator correlating a respective one of the local code sequences with the 

20 received spread signal to produce a respective despread multipatii data 

21 signal component having a carrier phase value; 
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b) weighting means for scaling the data value and for aligning the 
carrier phase value of the despread multipath data responsive to the 
respective multipath weighting value; and 

c) first combining means for combining each one of the scaled and 
aligned data signal components to produce the data value. 

14. The data AMF apparatus of claim 13, wherein: 

a) each of the plurality of spreading code correlators further includes 
multiplication means for multiplying the spread signal with a respective one of the local 
code sequences to produce a correlated signal value and accumulation means for 
accumulating the correlated signal value for a predetermined period to produce a despread 
multipath data signal component having a carrier phase which corresponds to the carrier 
signal phase of the respective received multipath signal component; and 

b) the aligning means comprises a plurality of multipliers, each multiplier 
multiplying a respective one of the despread multipath data signal components with a 
respective one of the multipath signal weighting values, and cadi multiplier producing one 
weighted data signal component of a plurality of weighted data signal components. 

15. The adaptive matched filter (AMF) apparatus of claim 13. wherein the pilot 
vector correlator means further comprises: 

local pilot code sequence generator means for generating a plurality of local code 
sequences, each of the code sequences being a code phase-shifted version of the pilot 
spreading code sequence; 

a plurality of pilot spreading code correlators, each pilot spreading code correlator 
correlating a respective one of the local code sequences with the ^read signal, each 
spreading code correlator comprising multiplication means for multiplying the spread 
signal with the respective one of the local code sequences to produce a correlated pilot 
signal value and accumulator means for accumulating the correlated pilot signal value for 
a predetermined period to produce a despread multipath pilot signal component with a 
carrier signal phase; wherein each one of the plurality of despread multipath pilot signal 
components is applied to a respective one of a plurality of low pass filters to produce a 
multipath signal weighting value corresponding to the carrier signal phase of the 
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15 respective received multipath signal component; each one of the plurality of despread 

16 multipath pilot signal components and the respective multipath signal weighting value is 

17 applied to a respective one of a plurality of multipliers; and each multipath pilot signal 

18 component is multiplied by the respective multipath signal weighting value to produce one 

19 scaled and phase rotated pilot signal component of a plurality of scaled and phase rotated 

20 pilot signal components having substantially equal carrier phases; and 

21 d) second combining means for combining the plurality of weighted pilot signal 

22 components to produce a pilot data value. 

1 16. A pilot vector correlator apparatus a) for receiving a spread signal, b) for 

2 collecting signal power from a spread pilot channel which is a component signal of the 

3 spread signal wherein the spread signal has a plurality of received multipath signal 

4 components to produce a pilot data value, said spread pilot channel being ^read by a 

5 predetermined pilot spreading code sequence, and c) for providing a plurality of multipath 

6 signal weighting values determined from the spread pilot channel; the j^)paratus 

7 comprising: 

8 local pilot code sequence generator means for generating a plurality of local code 

9 sequences, each of the code sequences being a code phase-shifted version of the pilot 

10 spreading code sequence; 

11 a plurality of pilot spreading code correlators, each pilot spreading code correlator 

12 correlating a respective one of the local code sequences with the spread signal, each 

13 spreading code correlator comprising a multiplier which multiplies the ^read signal by a 

14 respective one of the local code sequences to produce a correlated pilot signal value and 

15 accumulator means for accumulating the correlated signal for a predetermined period to 

16 produce a despread multipath pilot signal component with a carrier signal; wherein each 

17 one of the plurality of despread multipath pilot signal components is applied to a 

18 respective one of a plurality of low pass filters, to produce a respective one of the 

19 plurality of multipath signal weighting values, each multipath signal weighting value 

20 corresponding to a carrier signal phase value of the respective received multipadi signal 

21 component; each one of the plurality of deq)read multipath pilot signal components and 

22 the re^)ective multipath signal weighting value being ^plied to a respective one of a 



SUBSTITUTE SHEET (RULE 26) 



wo 97/02675 



PCT/DS96/11059 



-74- 

plurality of multipliers, wherein each multipath pilot signal componrat is multiplied by 
the respective weighting value to produce a respective phase rotated pilot signal 
component of a plurality of phase rotated pilot signal components having substantially 
equal carrier phase values; and 

d) combining means for combining the plurality of derotated pilot signal 
components to produce die pilot data value. 

17. The pilot vector correlator apparatus of claim 16, further comprising: 

a phase locked loop (PLL) which measures a carrier phase error of the pilot data 
value and produces a composite carrier phase error signal; wherein the phase error signal 
and each one of the plurality of despread multipath pilot signal componrats and the 
respective multipath signal weighting value are applied to a respective one of a plurality 
of multipliers, and each multipath pilot signal component is multiplied by the respective 
weighting value and the phase error signal to produce one scaled and phase rotated pilot 
signal component of the plurality of scaled and phase rotated pilot signal components 
having substantially equal carrier phases. 

18. An improved data adaptive matched filter (AMF) apparatus for collecting 

, signal power of a spread data channel in a spread-spectrum communication system from a 
spread signal having a plurality of multipath signal components to produce a despread 
data value, wherein said spread signal includes a spread pilot channel and said spread data 
channel employs a predetermined spreading code sequence; tiie improved data AMF 
apparatus comprising: 

pilot vector correlator means for receiving die spread signal and for providing a 
plurality of multipatii signal weighting values determined from die spread pilot channel, 
each multipatii signal weighting value corresponding to a respective different carrier 
signal phase of the received multipath signal component; 

clock signal generator means for producing a clock signal; 

code sequence generator means for generating a predetermined code sequence 
signal having a plurality of code chip values and substantially equivalent to die spreading 
code sequence of tiie spread data channel, said code sequence generator means being 
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coupled to the clock signal generator means for sequentially providing eadi spreading 
code value responsive to the clock signal; 

a data AMF comprising: 

a) a shift register (SR) responsive to the clock signal and having a plurality of 
stages including a first stage and last stage, said predetennined code sequence signal being 
z^plied to the first stage, wherein each stage defines a ieq)ective t^, and each t^ 
produces a signal which corresponds to successive ones of the ^reading code values; 

b) a plurality of signal multipliers, each signal multiplier multiplying a tap output 
value by a respective multipadi signal weighting value to produce one respective multipath 
despreading signal value of a plurality of multipath despreading signal values; 

c) combining means for combining all of the plurality of multipath despreading 
signal values to produce a despreading signal; 

d) multiplying means for multiplying the spread signal by the despreading signal to 
produce a despread data signal; and 

e) accumulating means for accumulating the despread data signal for a 
predetermined period to produce the despread data value. 

19. A code sequence generator apparatus which generates a plurality of spreading 
code sequences including a master spreading code sequence, the plurality of spreading 
code sequences having relatively low mutual cross correlation, and having a 
predetermined mutual code phase relationship, said code sequence generator apparatus 
comprising: 

a clock generator means for generating a clock signal 

a linear feedback shift register (LFSR), responsive to the clock signal and having a 
plurality of stages including a first stage and a last stage, each stage defining a respective 
tap, each tap producing a tap signal; wherein a predetermined group of the tap signals 
including the tap signal of tiie last stage are applied to logic circuitry which combmes the 
tap signals to produce a feedback spreading code signal, said feedback spreading code 
signal being applied as an input signal to the first stage of the LFSR; 
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13 first memory means for storing a plurality of ^reading-code seeds, each 

14 spreading-code seed comprising a set of spreading-code sequence bit values, and said first 

15 memory being connected to the LFSR and being responsive to a load signal for 

16 transferring each one of a predetermined set of the q)reading-code sequence bit values of 

17 a selected one of the plurality of spreading-code seed into a req)ective one of the shift 

18 register stages of the LSFR; 

19 code generator controller means for selectmg one of the plurality of spreading 

20 code seeds to detemine die plurality of spreading code sequences and for providing the 

21 load signal indicating said one spreading-code seed; 

22 wherein said LSFR is responsive to the clock signal to sequentially transfer each 

23 respective tap signal from one stage to the next stage, from the first stage to die last stage 

24 and for transferring the feedback spreading code value to the first stage, and each 

25 successive one of the tap values of the last stage defines the master spreading code 

26 sequence 

^ second memory means being responsive to die clock signal for providing a 

28 rq)etitive even code sequence, said even code sequence having relatively low cross 

29 correlation with the master spreading sequence and having an even number of diip 

30 q)reading values; 

'1 a plurality of cascade connected feedforward means, coupled to receive die master 

32 spreading code sequence, for providing a plurality of code sequences, each code sequence 

33 being a distinct spreading code sequence of said plurality of ^reading code sequences. 

34 said feedforward means being responsive to die clock signal, to provide a plurality of 

35 spreading code sequences; and 

36 a plurality code sequence combining means, each code sequence combining means 

37 for combming respective spreading code sequence witii said even code sequence to 

38 produce a plurality of relatively long spreading code. 

1 20. The code sequence generator apparatus of claim 19, wherein die plurality of 

2 cascade connected feedforward means includes: 

3 receiving means for receiving die master spreadmg sequence; 
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a feedforward circuit having a plurality of cascade connected feedforward logic • 
sections, each logic section defining a t^ which provides one of the plurality of spreading 
code sequences, including a first feedforward logic section and a last feedforward logic 
section and connected sequentially from tiie first feedforward logic section to the last 
feedforward logic section, each feedforward logic section comprising a smgle delay 
element having an input terminal which receives and input signal and an output terminal 
which provides an output signal, and logic combining means for logically combming the 
input signal witfi the ou^ut signal to produce the respective spreading code sequence. 

2L The code sequence generator claim 20, wherein tiie code sequence combining 
means comprises an EXCLUSIVE-OR logic circuit. 

22. The code sequence generator j^paratus of claim 20, whercm the logic 
combining means comprises an EXCLUSIVE-OR logic circuit for performing modulo-2 
addition. 
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